Benutzer:Morn/Modifikationen

aus Memory Alpha, der freien deutschen Star-Trek-Datenbank
< Benutzer:Morn
Version vom 10. Dezember 2005, 13:05 Uhr von imported>Kobi (yeargenerator.py: Jahrhundert-Fix)
Spring zu: Navigation, suche

Auf dieser Seite werden Modifikationen des pyWikipediaBot-Frameworks aufgelistet:

families\memoryalpha_family.py

# -*- coding: utf-8  -*-
import family
    
# The Memory Alpha family, a set of StarTrek wikis.

class Family(family.Family):
    def __init__(self):
        family.Family.__init__(self)
        self.name = 'memoryalpha'
    
        self.langs = {
            'de': None,
            'en': None,
            'fr': None,
            'nl': None,
            'sv': None,
            }
    
        # Most namespaces are inherited from family.Family.
        self.namespaces[4] = {
            '_default': u'Memory Alpha',
        }
        self.namespaces[5] = {
            '_default': u'Memory Alpha talk',
            'de': u'Memory Alpha Diskussion',
            'fr': u'Discussion Memory Alpha',
            'nl': u'Overleg Memory Alpha',
            'sv': u'Memory Alphadiskussion',
        }
        
        # A few selected big languages for things that we do not want to loop over
        # all languages. This is only needed by the titletranslate.py module, so
        # if you carefully avoid the options, you could get away without these
        # for another wiki family.
        self.biglangs = ['en', 'de', 'nl', 'sv', 'fr']
    
        # attop is a list of languages that prefer to have the interwiki
        # links at the top of the page.
        self.interwiki_attop = []
        # on_one_line is a list of languages that want the interwiki links
        # one-after-another on a single line
        self.interwiki_on_one_line = []
        
        # String used as separator between interwiki links and the text
        self.interwiki_text_separator = ''
        
        # Similar for category
        self.category_attop = []
        # on_one_line is a list of languages that want the category links
        # one-after-another on a single line
        self.category_on_one_line = ['en', 'fr', 'de', 'nl', 'sv']
        
        # String used as separator between category links and the text
        self.category_text_separator = ''

    def hostname(self,code):
        return 'www.memory-alpha.org'

    def path(self, code):
        return '/%s/index.php' % code

    def version(self, code):
        return "1.4"

yeargenerator.py

#coding: iso-8859-1
"""
This script is based on Andre Engels' "pagefromfile.py" and
reads a template saved in "yeartemplate.txt" or another file specified below.
It is intented to set up the individual year entries in Memory Alpha.

Currently the arguments given below are needed, there is no fallback procedure
written yet:

Specific arguments:
-start:xxx  Specify the year to start with
-end:xxx    Specify the year that not created anymore-utf        The input file is UTF-8

Note the '-utf' option is necessary on older versions of Windows;
whether it's necessary or useful on Windows XP and/or other
operating systems is unclear.
"""
#
# (C) Andre Engels, 2004
# formatted to match Memory Alpha (www.memory-alpha.org)
# by Jan Hendrik "Kobi" Kobarg
#
# Distribute under the terms of the PSF license.
#

import wikipedia
import re, sys

msg={
    'en':u'Automated import of articles',
    'nl':u'Geautomatiseerde import',
    'pt':u'Importa�o autom�ica de artigo',
    'de':u'Robot: Automatische Seitenerstellung'
    }

# The following are the standard settings for an empty Memory Alpha language
# first year is 1900, last year is 2379.
# Template is stored in "yeartemplate.txt".
startyear = int(1900)
endyear = int(2380)
filename = "yeartemplate.txt"
include = False
utf = False

def putpage(t, year):
    try:
        year_before = str(year - 1)
        year_after = str(year + 1)
        if year % 100 == 0:
            century = str(year / 100)
        else:
            century = str(year / 100 + 1)
        decade = str(year / 10)
        page = t %(year_before, century, decade, year_after, str(year), str(year), str(year), str(year))
        title = str(year)
        pl = wikipedia.Page(mysite,wikipedia.UnicodeToAsciiHtml(title))
        print "\n==== Processing %s ====" %title
        if pl.exists():
            print "Page %s already exists, not adding!"%title
        else:
            pl.put(page, comment = commenttext, minorEdit = False)
    except AttributeError:
        print "No title found - skipping a page."
    return


def main():
    text = []
    if utf:
        f=codecs.open(filename,'rb',encoding='utf-8')
    else:
        f=open(filename,'r')
    for line in f.readlines():
        text.append(line)
    text=''.join(text)

    for year in range(startyear, endyear):
        putpage(text, year)

for arg in sys.argv[1:]:
    arg = wikipedia.argHandler(arg, 'pagefromfile')
    if arg:
        if arg.startswith("-start:"):
            startyear=int(arg[7:])
        elif arg.startswith("-end:"):
            endyear=int(arg[5:])
        elif arg.startswith("-file:"):
            filename=arg[6:]
        elif arg=="-include":
            include = True
        elif arg=="-utf":
            import codecs
            utf = True
        else:
            print "Disregarding unknown argument %s."%arg
mysite = wikipedia.getSite()
commenttext = wikipedia.translate(mysite,msg)

try:
    main()
except:
    wikipedia.stopme()
    raise
else:
    wikipedia.stopme()

yeartemplate.txt

file needed to make yeargenerator work:

German version
== Ereignisse ==
* ''keine bisher''


{| class="browser"
|- 
| class="prev" | [[%s]]
| class="topic" | [[%s. Jahrhundert]]<br/>[[%s0er]]
| class="next" | [[%s]]
|}
[[Kategorie:Zeitlinie]]
[[en:%s]]
[[fr:%s]]
[[nl:%s]]
[[sv:%s]]