Source code for scripts.create_categories

# -*- coding: utf-8 -*-
Program to batch create categories.

The program expects a generator of category titles to be used
as suffix for creating new categories with a different base.

The following command line parameters are supported:

-always         Don't ask, just do the edit.

-parent         The name of the parent category.

-basename       The base to be used for the new category names.

-overwrite:     Existing category is skipped by default. Use this option to
                overwrite a category.


    python create_categories \
        -lang:commons \
        -family:commons \
        -links:User:Multichill/Wallonia \
        -parent:"Cultural heritage monuments in Wallonia" \
        -basename:"Cultural heritage monuments in"

The page 'User:Multichill/Wallonia' on commons contains
category links like [[Category:Hensies]], causing this script
to create [[Category:Cultural heritage monuments in Hensies]].

# (C) Multichill, 2011
# (C) xqt, 2011-2019
# (c) Pywikibot team, 2013-2019
# Distributed under the terms of the MIT license.
from __future__ import absolute_import, division, unicode_literals

import pywikibot
from import AutomaticTWSummaryBot, SingleSiteBot
from pywikibot import pagegenerators
from import Namespace
from import UnicodeType

[docs]class CreateCategoriesBot(SingleSiteBot, AutomaticTWSummaryBot): """Category creator bot.""" summary_key = 'create_categories-create'
[docs] def __init__(self, **kwargs): """Initializer.""" self.availableOptions.update({ 'basename': None, 'parent': None, 'overwrite': False, }) super(CreateCategoriesBot, self).__init__(**kwargs)
[docs] def init_page(self, item): """Create a category to be processed with the given page title.""" page = super(CreateCategoriesBot, self).init_page(item) title = page.title(with_ns=False) if page.namespace() != Namespace.CATEGORY: # return the page title to be skipped later within skip_page return title category = pywikibot.Category(, '{} {}'.format(self.getOption('basename'), title)) text = ('[[{namespace}:{parent}|{title}]]\n{category}\n' .format(, parent=self.getOption('parent'), title=title, category=page.title(as_link=True))) category.text = text return category
[docs] def treat_page(self): """Create category in local site for that page.""" newtext = self.current_page.text self.current_page.text = '' self.put_current(newtext, ignore_server_errors=True)
[docs] def skip_page(self, page): """Skip page if it is not overwritten.""" if isinstance(page, UnicodeType): pywikibot.warning(page + ' is not a category, skipping') return True if page.exists() and not self.getOption('overwrite'): pywikibot.warning('{} already exists, skipping'.format(page)) return True return super(CreateCategoriesBot, self).skip_page(page)
[docs]def main(*args): """ Process command line arguments and invoke bot. If args is an empty list, sys.argv is used. @param args: command line arguments @type args: str """ options = {} # Process global args and prepare generator args parser local_args = pywikibot.handle_args(args) gen_factory = pagegenerators.GeneratorFactory() for arg in local_args: option, _, value = arg.partition(':') opt = option[1:] if arg in ('-always', '-overwrite'): options[opt] = True elif option in ('-parent', '-basename'): if value: options[opt] = value else: gen_factory.handleArg(arg) missing = ['-' + arg for arg in ('basename', 'parent') if arg not in options] generator = gen_factory.getCombinedGenerator() if, missing_generator=not generator): return bot = CreateCategoriesBot(generator=generator, **options)
if __name__ == '__main__': main()