Utente:Alebot/Scripts interattivi

Da Wikisource.
(Reindirizzamento da Utente:Alebot/Scripts)

La situazione si evolve, ho "azzerato" quasi tutti gli script interattivi per riscriverli daccapo, partendo dal "motore".

Altra versione. Analogamente alla precedente, l'avvio da prompt pone due semplici domande: Avvio il bot? (si, s -> predisposizione avvio script a tempo; qualsiasi altro input, esce nel prompt python) Secondi: (impostare il numero di secondi fra i cicli)

Al momento esegue una lttura di eventuali query intersezione ogni ciclo, e una verifica di nuove pagine nei nsPrincipale, nsAutore, nsIndice e nsPagina ogni due cicli.

  • Aggiornamento 20 luglio 2010, ch'è dentro anche builder(), buildNs0() (versione da correggere), e appena aggiunto accoppaPagine() che esegue la conversione Pagina -> pages index

Avviso a chi si avventura nella lettura: si tratta di un'orrenda collezione di funzioni, scritte secondo un ordine "push": scrivo le nuove funzioni in testa per trovarle ;-). Ossia: non hanno alcun ordine logico. Unico indizio: la routine fondamentale, che esegue l'elaborazione del testo di ogni pagina che il bot trova in UltimeModifiche, è elabora(). :-)

Siete avvisati.

Aggiornamento 30 agosto 2010[modifica]

Lo script è ulteriormente appesantito dalla gestione dei dati introdotti con il tl Ns0; sono state introdotte inoltre due simpatiche routine di correzione automatica:

  1. aggiornamento automatico del SAL delle pagine Indice, con verifica che scatta ad ogni modifica su una pagina dell'indice (eventuali valori SAL erronei, introdotti a mano, sono "rullati" dal calcolo automatico);
  2. verifica presenza del tl Qualità in ogni pagina creata/modificata in Ns0, e in caso di assenza, assegnazione d'ufficio del SAL 25%.

Versione 5.8.10: contiene listaNs0(), sommario(), splittaPagina(), verificaSezioni()

#!/usr/bin/python
# -*- coding: utf-8 -*-
# versione al 30 agosto 2010
import wikipedia
import pickle
import catlib
import pagegenerators
from datetime import date
from dummy_threading import Timer
import query as wquery
import urllib

from time import gmtime, strftime
from random import random
import os,sys




a="{{}}"
b="}}"
autoreCitato={}  

nsobs="0|102|108|110" # principale, autore, pagina, indice
output="cp1252"

wnamespaces={'': 0, 'Principale': 0, 'Discussioni categoria': 15, 'MediaWiki': 8, 'Template': 10,
            'Discussioni portale': 107, 'Categoria': 14, 'Discussioni progetto': 105,
            'Discussioni file': 7, 'Discussioni indice': 111, 'Discussioni aiuto': 13,
            'Media': -2, 'Discussioni template': 11, 'Autore': 102, 'Speciale': -1,
            'Discussioni Wikisource': 5, 'Pagina': 108, 'Utente': 2, 'Wikisource': 4,
            'Progetto': 104, 'Discussioni utente': 3, 'Indice': 110, 'Discussioni pagina': 109,
            'Discussioni MediaWiki': 9, 'Discussione': 1, 'Discussioni autore': 103, 'Portale': 106,
            'File': 6, 'Aiuto': 12}
vecchiePagine=[]

# produce una lista di pagine con prefisso determinato
def prefixGen(prefisso, namespace=None,includeredirects=False):
    generatore=pagegenerators.PrefixingPageGenerator(prefisso,includeredirects=includeredirects, namespace=namespace)
    lista=[]
    for i in generatore:
        lista.append(i.title())
    return lista # restituisce la lista di titoli

#genera i tl|Ns0 nel ns Pagina a partire da page index nella pagina testuale
def pageToNs0(nomePagina):
    testoPagina=leggi_pagina(nomePagina)
    pagesTag=find_stringa(testoPagina,"<pages","/>")
    if pagesTag=="":
        return None,None,None,None
    includiIntestazione=find_stringa(testoPagina.replace("includiIntestazione","IncludiIntestazione"),\
                                     "{{IncludiIntestazione","}}")+"|"
    includiIntestazione=includiIntestazione.replace(" =","=")
    pagesTag=pagesTag.replace(" =","=")
    index={}
    for i in [" index="," from="," to="," fromsection="," tosection="]:
        index[i[1:-1]]=pagesTag.find(i)
      
    l=[]
    for i in ["index","from","to","fromsection","tosection"]:
        elemento=[i,index[i],len(pagesTag)]
        for j in ["index","from","to","fromsection","tosection"]:
            if index[j]>elemento[1] and index[j]<elemento[2]:
                    elemento[2]=index[j]
        l.append([i,pagesTag[elemento[1]:elemento[2]]])
    pagina=""
    sezione=""
    base=""
    sezione1=None
    sezione2=None
    for i in l:
        if i[0]=="from":
            pagina=i[1].replace("from=","").strip()
        if i[0]=="index":
            base=i[1].replace("index=","").strip()
            base=base[1:-1]
        if i[0]=="fromsection":
            sezione=i[1].replace("fromsection=","").strip()
    pagina="Pagina:"+base+"/"+pagina
    if sezione!="":
        sezione1="<section begin="+sezione+" />"
        sezione2='<section begin="'+sezione+'" />'
    ns0="{{Ns0|#1|#2}}"
    ns0=ns0.replace("#1",nomePagina)
    #print includiIntestazione
    titolo=find_stringa(includiIntestazione,"sottotitolo=","|").strip()
    ns0=ns0.replace("#2",titolo)
    
    return ns0,pagina,sezione1,sezione2

# estrae i dati da una pagina Indice e restituisce una lista

##def elencoLinksIndice(indice="Indice:Africa orrenda.djvu"):
##    tutte=True
##    site=wikipedia.getSite()
##    page=wikipedia.Page(site,indice)
##
##    # calcolo nome x url
##    nomeindice="/wiki/"+page.urlname()
##    
##    #lettura HTML originario (prima delle alterazioni js)
##    testo=leggi_pagina_html(nomeindice)
##    #ricerca di tutti i tag <a href..>...</a> e salvataggio su file
##    pagine=produci_lista(testo,'<a href="',"</a>",1)
##    
##    link=[]
##    for i in pagine:
##         
##       if ('title="Pagina:' in i) and ("class=" in i):
##           
##           if not titolo in titoli:
##               
##               link.append(i)
##    return links
##    

def elencoPagineIndice(indice="Indice:Ardigo - Scritti vari.djvu",tutte=False,links=False):
    #elenco_pagine=[]
    #inizializzazione oggetto Page su pagina indice
    site=wikipedia.getSite()
    page=wikipedia.Page(site,indice)

    # calcolo nome x url
    nomeindice="/wiki/"+page.urlname()
    
    #lettura HTML originario (prima delle alterazioni js)
    testo=leggi_pagina_html(nomeindice)
    #print testo
    salva_pcl(testo,"testoIndice")
    
    #ricerca di tutti i tag <a href..>...</a> e salvataggio su file
    pagine=produci_lista(testo,'<a href="',"</a>",1)
    print "Numero elementi totali:",len(pagine)
    titoli=[]
    link=[]
    for i in pagine:
         if tutte:
           if ('title="Pagina:' in i) and ("class=" in i):
               titolo=find_stringa(i,'title="','"').replace(" (tuttora non scritto)","")
               #print titolo
               #qp=find_stringa(i,'class="','"')
               if not titolo in titoli:
                   #elenco_pagine.append([titolo,qp])
                   titoli.append(titolo)
                   link.append(i)
                   #print i,
         else:
            if ('title="Pagina:' in i) and ("class=" in i) and (not " (tuttora non scritto)" in i):
               titolo=find_stringa(i,'title="','"')
               if not titolo in titoli:
                  titoli.append(titolo)
                  link.append(i)
                  
   
    if links:
       risultato=link
    else:
       risultato=titoli
       

    return risultato

# restutuisce un dizionario delle pagine in una pagina Incide, accoppiate con la
# loro rappresentazione impostata da pagelist
def estraiDatiLinks(indice): # riceve da estraiPagineIndice una lista di links
    
   result={}
   lista=elencoPagineIndice(indice,False,True)
   for i in lista:
      link=i
      qp=find_stringa(link,'class="','"')
      titolo=find_stringa(link,'title="','"')
      span=find_stringa(link,"<span","</span>",1)
      if span>"":
         link=link.replace(span,"")
      ancora=find_stringa(link,">","<")
      result[titolo]=[ancora,qp]
   return result

def pagine2djvu(result):
    
    links={}
    for i in result.keys():
        links[result[i][0]]="[[../"+i[i.find("/")+1:]+"|"+result[i][0]+"]]"
    return links

def rigaIndice(testo):
    l=testo.split("\n")
    for i in range(len(l)):
        if l[i].startswith(":"):
            l[i]=l[i][1:]
            riga=l[i].split(" ")
            ri=riga.pop(0)
            rf=riga.pop()
            riga=" ".join(riga)
            riga="{{RigaIndice|"+ri+"|"+riga+"|"+rf+"}}"
            l[i]=riga
    testo="\n".join(l)
    return testo

# esegue aggiornamento massivo della Qualità in un'intera opera
def aggiustaQualita(prefisso, avz="75%", data="31 luglio 2010",arg="novelle"):
    n=0
    base=u"{{Qualità|avz=#avz#|data=#data#|arg=#arg#}}".replace("#avz#",avz)\
.replace("#data#",data).replace("#arg#",arg)
    lista=prefixGen(prefisso)
    for nomePagina in lista:
        testo=leggi_pagina(nomePagina)
##        print testo
        q=find_stringa(testo,u"{{Qualità|","}}",1)
        if q!="":
            testo=testo.replace(q,"")
        testo=base+testo
        testo=elaboraTesto(testo)
        scrivi_pagina(testo,False,nomePagina,commento=u"Aggiornamento tl qualità via bot")
    return
        
# batch di elaborazione di un testo (varie routine)
def elaboraTesto(testo):
    testo=apos(testo)
    testo=conteggioPagine(testo)
    testo=accoppaCapitolo(testo)
    testo=accoppaPagina(testo)
    return testo                     
    
    
def aggiungiQualita(lista,numeromax=10000):
    n=0
    q=u"{{Qualità|avz=indeterminato|data=27 luglio 2010|arg=Da definire}}"
    for i in lista:
        nomePag=i
        testo=leggi_pagina(nomePag)
        if not u"{{Qualità|" in testo:
            print testo[:300]
            if "{{Intestazione" in testo or "{{IncludiIntestazione" in testo:
                testo=accoppaCapitolo(q+testo)
                scrivi_pagina(testo,False,nomePag,commento=u"Aggiunta template qualità indeterminata")
                n=n+1
                
                if n>numeromax:
                    break
    return


def pagineToPagesIndex(lista):
    
   for capitolo in lista:
      testoCapitolo=leggi_pagina(capitolo)
      testoCapitolo1=accoppaPagina(testoCapitolo)
      if testoCapitolo1!=testoCapitolo:

         scrivi_pagina(testoCapitolo,False,capitolo,"Conversione pagine->pages index via bot")
      
   return
   
def accoppaPagina(testoCapitolo):
   pagesIndex='<pages index= from= to= fromsection= tosection= />'
   testoCapitolo=testoCapitolo.replace("{{Pagina","{{pagina")
   #print capitolo
   if testoCapitolo.count("{{pagina")>0:
      print testoCapitolo
      pagine=produci_lista(testoCapitolo,"{{pagina","}}",1)
      for i in pagine:
         if not (".djvu/" in i.lower() or ".pdf/" in i.lower()):
            return testoCapitolo
      print pagine
      base=find_stringa(pagine[0],"pagina|","/")
      pi=pagesIndex.replace("index=","index="+'"'+base+'"')
      l=[]
      for i in pagine:
          if i.count("|")==2:
              l1=find_stringa(i,"/","|")
              l2=find_stringa(i,"section=","}}")
          else:
              l1=find_stringa(i,"/","}}")
              l2=""
          l.append([eval(l1),l2])
      l.sort()
      lmin=min(l)
      lmax=max(l)
      pi=pi.replace("from=","from="+str(lmin[0]))
      pi=pi.replace("to=","to="+str(lmax[0]))
      if lmin[1]>"":
          pi=pi.replace("fromsection=","fromsection="+lmin[1])
      if lmax[1]>"":
          pi=pi.replace("tosection=","tosection="+lmax[1])
      for i in range(len(pagine)):
          if i==0:
              testoCapitolo=testoCapitolo.replace(pagine[i],pi)
          else:
              testoCapitolo=testoCapitolo.replace(pagine[i],"")
      print pi
   return testoCapitolo

# script di sola visualizzazione, non modifica wiki
def allineaNs0(nomePagina):
   testoPagina=leggi_pagina(nomePagina)
   includiIntestazione=find_stringa(testoPagina,"{{IncludiIntestazione|","}}",1)
   sottotitolo=find_stringa(includiIntestazione,"sottotitolo=","|").strip()
   if sottotitolo=="":
      sottotitolo=find_stringa(includiIntestazione,"sottotitolo=","}}").strip()
   
   #print testoPagina
   pageIndex=find_stringa(testoPagina,"<pages index","/>",1)
   if pageIndex>"":
      nPag=find_stringa(pageIndex,"from="," ")
      nSec=find_stringa(pageIndex,"fromsection="," ")
      index=find_stringa(pageIndex,'index="','"')
      parti=nomePagina.split("/")
      nomePag=parti[len(parti)-1]
      nomeMain=parti[0]
      if len(parti)>2:
         prefisso="/".join(parti[1:len(parti)-1])+"/"
      else:
         prefisso="/"
      ns0="{{Ns0|"+prefisso+nomePag+"|"+sottotitolo+"}}"
      print "Ns0:",ns0
     
   return
      
# vecchio script di conversione precedente infotesto
def normalizzaInfotesto(progetto):
   pagina=wikipedia.Page("it","Template:Infotesto "+progetto)
   lista=pagina.getReferences(onlyTemplateInclusion=True)
   for i in lista:
      if not ("/" in i.title() or "Discussioni pagina:" in i.title()):
         print i.title()
         testo=i.get()
         #print testo
         testoNew=testo.replace("Infotesto "+progetto,"Infotesto\n| Progetto= "+progetto)
         if testoNew!=testo:
            
            scrivi_pagina(testoNew,False,i.title(),commento="Normalizzazione Infotesto")
   return


def normalizzaInfotestoSottopagine(progetto):
   pagina=wikipedia.Page("it","Template:Infotesto "+progetto)
   lista=pagina.getReferences(onlyTemplateInclusion=True)
   for i in lista:
      if "Discussione:" in i.title() and "/" in i.title():
         print i.title()
         testo=i.get()
         #print testo
         infotesto=find_stringa(testo,"{{Infotesto","}}",1)
         if infotesto!="":
            
            testoNew=testo.replace(infotesto,"{{IncludiInfotesto}}")
            if testoNew!=testo:
               print testoNew
               scrivi_pagina(testoNew,False,i.title(),commento="Normalizzazione Infotesto")
   return

def creaPrecSucc(paginaPrincipale="Sentenza Tribunale penale di Perugia - Vicenda Federconsorzi"):
   testo=leggi_pagina(paginaPrincipale).replace("{{Testo","{{testo")
   lista=produci_lista(testo,"{{testo","}}",1)
   print "la pagina contiene ",len(lista),"link a sottopagine"
   for i in range(len(lista)):
      param=find_stringa(lista[i],"{{","}}").split("|")[1]
      if param.startswith("/"):
         lista[i]=paginaPrincipale+param
         
      else:
         lista[i]=param
   #print lista
   for i in range(len(lista)):
      nomePag=lista[i]
      linkPagPrec=""
      linkPagSucc=""
      if not i==0:
         linkPagPrec=abs2rel(lista[i],lista[i-1])
      if not i==len(lista)-1:
         linkPagSucc=abs2rel(lista[i],lista[i+1])
      testo=leggi_pagina(nomePag).replace("{{includiIntestazione","{{IncludiIntestazione")
      incInt=find_stringa(testo,"{{IncludiIntestazione","}}",1)
      incIntNew=incInt.replace("prec =","prec=").replace("succ =","succ=")
      if not ("prec=" in incIntNew or "succ=" in incIntNew):
         incIntNew=incIntNew.replace("}}","|prec="+linkPagPrec+"}}").replace("}}","|succ="+linkPagSucc+"}}")
         testo1=testo.replace(incInt,incIntNew).replace("}}==","}}\n==")
         scrivi_pagina(testo1,False,nomePag)
      elif "}}==" in testo:
         scrivi_pagina(testo.replace("}}==","}}\n=="),False,nomePag)
 
   return

def abs2rel(nomePagina,link):# restituisce titolo2 relativo
    nomePagina=nomePagina.split("/")
    link=link.split("/")
    abs2=[]
    for i in range(len(nomePagina)):
        abs2.append("..")
    while nomePagina[0]==link[0]:
        
        nomePagina.pop(0)
        link.pop(0)
        abs2.pop()
        if len(nomePagina)==0 or len(link)==0:
            break
        
    result="/".join(abs2+link)
    if result.endswith(".."):
        result=result+"/"
    if not result.startswith(".."):
        result="/"+result
    return result

   
def fixDjvu(testo):
   header=find_stringa(testo,u"\u2014","\n",1)
   testo=testo.replace(header,"")
   testo=testo.replace(u"\ufffd\ufffd","<poem>",1)
   testo=testo.replace(u"\n\n\ufffd\ufffd","</poem>",1)
   testo=testo.replace(u"\ufffd","")
   
   
   return testo

def riempiPagine(indice):
   if indice.startswith("Indice:"):
      base=indice.replace("Indice:","Pagina:")+"/"
   else:
      base="Pagina:"+base+"/"
   n=1
   while True:
      n=raw_input("Numero pagine")
      if n.isdigit():
         n=eval(n)
         break
   for i in range(1,n):
      testo=leggi_pagina(base+str(i))
      if testo=="":
         scrivi_pagina("<!-- qui testo -->",False,base+str(i))
   return
      
  
def buildNs0(listaNs0, baseIndex=None,scrivi=False, riscrivi=False): # riceve il nome di una pagina ns0 principale e la lista ln
                        # prodotta da builder()
  
      
   capitoli=[]
   schema=u'''{{Qualità|avz=50%|data=7 agosto 2010|arg=poesie}}{{IncludiIntestazione
| Argomento=Filosofia
| sottotitolo = #sottotitolo#
| prec = #prec#
| succ = #succ#
}}

<pages index="#baseindex#" from=#from# to=#to# fromsection=#fromsection# tosection=#tosection# />

{{Sezione note}}
{{Conteggio pagine|[[Speciale:Statistiche]]}}'''
   for i in range(len(listaNs0)):
      capitolo=schema
      dc=find_stringa(listaNs0[i][1],"{{Ns0|","}}").split("|")
      nomeCapitolo=dc[0]
      titoloCapitolo=dc[1]
      capitolo=capitolo.replace("#sottotitolo#",titoloCapitolo)\
                .replace("#baseindex#",baseIndex)\
                .replace("#from#",listaNs0[i][4])\
                .replace("#to#",listaNs0[i][6])\
                .replace("#fromsection#",listaNs0[i][5])\
                .replace("#tosection#",listaNs0[i][7])

      capitolo=capitolo.replace("#prec#",listaNs0[i][8])
      if i<len(listaNs0)-1:
          capitolo=capitolo.replace("#succ#",listaNs0[i][9])
      else:
          capitolo=capitolo.replace("#succ#","")
      print capitolo
##      nomeCapitolo=main+"/"+listaNs0[i][0]
      capitoli.append([nomeCapitolo,capitolo])
      if riscrivi:
         scrivi_pagina(capitolo, False,nomeCapitolo,"Riscrittura capitolo via bot")
      
      elif scrivi:
         if leggi_pagina(nomeCapitolo)=='':
            scrivi_pagina(capitolo, False,nomeCapitolo,"Creazione capitolo via bot")
      
   return capitoli

# la routine suddivide una pagina Pagina in header, testo, footer
# e segmenta il testo 
def splittaPagina(pagina): # riceve il testo Unicode della pagina
   header=find_stringa(pagina,"<noinclude><page","</noinclude>",1)
   footer=find_stringa(pagina,"<noinclude>\n<ref","</noinclude>",1)
   testo=pagina.replace(header,"").replace(footer,"")
   testo=splittaTesto(testo)
   
   return [header, testo, footer]

# la routine suddivide il testo in una lista di segmenti tipo testo, tipo ns0
# o tipo section

def convertiQuality(testo):
    qualityTemplate=find_stringa(testo,"{{PageQuality","}}",1)
    lq=find_stringa(qualityTemplate, "{{PageQuality|","}}").split("|")
    schema='<pagequality level="#1" user="Alebot" />'
    nquality=schema.replace("#1",lq[0])
    testo=testo.replace(qualityTemplate,nquality)
    return testo
    
def aggiornaListaNs0(nomePaginaPrincipale):
    listacapitoli=prefixGen(nomePaginaPrincipale)
    for i in listacapitoli:
        pag=wikipedia.Page("it",i)
        nomePagina=pag.title()
        if pag.isRedirectPage():
            print nomePagina,u" è un redirect"
        elif pag.isDisambig():
            print nomePagina,u" è una pagina disambigua"
        elif not pag.exists():
            print nomePagina,u" non esiste"
        else:
            aggiornaNs0(nomePagina)
    return


def aggiornaNs0(titolo):
    dati=pageToNs0(titolo) #    return ns0,pagina,sezione1,sezione2
    print dati
    if dati[1]==None:
        return "testo ",titolo,"senza tag pages index"
    testoPagina=leggi_pagina(dati[1])
    if "{{PageQuality" in testoPagina:
        testoPagina=convertiQuality(testoPagina)
        
    header,testo,footer=splittaPagina(testoPagina)
#    testoback=testo[:]
    nt=[]

    if dati[2]==None:
##        for i in testo:
##            if tipoSegmento(i)!="ns0":
##                nt.append(i)
##        testo=nt[:]
        if tipoSegmento(testo[0])=="ns0":
            testo[0]=dati[0]
        else:
            testo[0:0]=dati[0]
    else:
        if dati[2] in testo:
            sectPos=testo.index(dati[2])
            if tipoSegmento(testo[sectPos+1])!="ns0":
                testo[sectPos+1:sectPos+1]=dati[0]
            else:
                testo[sectPos+1]=dati[0]
        if dati[3] in testo:
            sectPos=testo.index(dati[3])
            if tipoSegmento(testo[sectPos+1])!="ns0":
                testo[sectPos+1:sectPos+1]=dati[0]
            else:
                testo[sectPos+1]=dati[0]
        
        else:
            print "Errore:section",dati[2],dati[3]," non trovata in ",dati[1]
#            testo=testoback
        
    testoPaginaNew="".join([header,"".join(testo),footer])
    if testoPaginaNew==testoPagina:
        print "Nessuna modifica"
    else:
        scrivi_pagina(testoPaginaNew,False,dati[1],"Aggiornamento Ns0 via aggiornaNs0()")
    return
            
    

    

def splittaTesto(testo): # new 1 8 2010
    testo=testo.replace("{{ns0","{{Ns0").replace(u"\ufeff","")
    lista=[]
    while "{{Ns0" in testo:
        if testo.startswith("{{Ns0"):
            ns0=find_stringa(testo,"{{Ns0","}}",1)
            lista.append(ns0)
            testo=testo.replace(ns0,"",1)
        else:
            segmento=testo[:testo.find("{{Ns0")]
            
            testo=testo.replace(segmento,"",1)
            segmento=splittaSegmento(segmento)
            lista=lista+segmento
    if len(testo)>0:
        testo=splittaSegmento(testo)
        lista=lista+testo
        testo=""
    return lista

def splittaSegmento(testo): 
    lista=[]
    while "<section" in testo:
        if testo.startswith("<section"):
            section=find_stringa(testo,"<section","/>",1)
            lista.append(section)
            testo=testo.replace(section,"",1)
        else:
            segmento=testo[:testo.find("<section")]
            testo=testo.replace(segmento,"",1)
            lista.append(segmento)
    if len(testo)>0:
        lista.append(testo)
    return lista
        
# la routine restituisce il tipo di un segmento del testo
def tipoSegmento(testo):
    if testo.startswith("<section"):
        tipo="section"
    elif testo.startswith("{{Ns0"):
        tipo="ns0"
    elif "<pagequality" in testo:
        tipo="header"
    elif "<references/>" in testo:
        tipo="footer"
    else:
        tipo="testo"
    return tipo
                           
# la routine elimina eventuali section e le riscrive in modo regolare
# restituisce un testo segmentato 
def verificaSezioni(testo): # testo è lista di segmenti
    if len(testo)<2 and tipoSegmento(testo[0])=="testo":
        True
    elif len(testo)==2 and tipoSegmento(testo[0])=="ns0":
        True
    else:
        testo0=testo[:]
        testo=[]
        for i in testo0:
            if tipoSegmento(i) in "ns0/testo": #qui le section esistenti vengono saltate
                testo.append(i)
        n=1
        for i in range(len(testo)):
            if i==0 and tipoSegmento(testo[i])=="testo":
                testo[i]="<section begin=x />".replace("x",str(n))+testo[i]+\
                          "<section end=x />".replace("x",str(n))
                n+=1
            elif tipoSegmento(testo[i])=="ns0":
                testo[i]="<section begin=x />".replace("x",str(n))+testo[i]
                if i==len(testo)-1:
                    testo[i]=testo[i]+"<section end=x />".replace("x",str(n))
                else:
                    testo[i+1]=testo[i+1]+"<section end=x />".replace("x",str(n))
                n+=1
        testo="".join(testo)
        testo=splittaTesto(testo)
    return testo

def ripassaNs0(base="Ardigo - Scritti vari.djvu",ini=200,fin=300):
    for i in range(ini,fin):
        nomePagina="Pagina:"+base+"/"+str(i)
        addSectionTag(nomePagina)
    return
        
    


def addSectionTag(nomePagina): # riceve un nome di pagina e normalizza le section
    testoPaginaOriginale=leggi_pagina(nomePagina)
    testoPagina=addSectionTagEngine(testoPaginaOriginale)
    if testoPagina!=testoPaginaOriginale:
        scrivi_pagina(testoPagina,False,nomePagina,commento="Normalizzazione section via bot")
    return

def addSectionTagEngine(testoPagina):
    
    sectionvoc={}
    listasec=produci_lista(testoPagina,"<section","/>",1)
    for i in listasec:
        if not i in ["<section begin=1 />","<section end=1 />","<section begin=2 />","<section end=2 />",\
                     "<section begin=3 />","<section end=3 />","<section begin=4 />","<section end=4 />",\
                     "<section begin=5 />","<section end=5 />","<section begin=6 />","<section end=6 />"]:
            sectionvoc[i.replace("<section","<*section")]=i
            sectionvoc[i]=i.replace("<section","<*section")
            testoPagina=testoPagina.replace(i,sectionvoc[i])
    
    testoPagina=splittaPagina(testoPagina)
    #print testoPagina
    if testoPagina[1]!=[]:
        
        testo=verificaSezioni(testoPagina[1])
        
        if testo!=testoPagina[1]:
            user=find_stringa(testoPagina[0],'user="','"',1)
            testoPagina[0]=testoPagina[0].replace(user,'user="Alebot"')
            testoPagina[1]="".join(testo)
        else:
            testoPagina[1]="".join(testo)
            
            
    testoPagina="".join(testoPagina)
            
    recsec=produci_lista(testoPagina,"<*section","/>",1)
    for i in recsec:
        testoPagina=testoPagina.replace(i,sectionvoc[i])
               
    return testoPagina
    

# trova le pagine di nome base in cui è usato Ns0 e produce una lista di coppie
# nomePagina,Ns0
def listaNs0(base="Ardigo - Scritti vari.djvu",filtro=False):
    l=[]
    p=wikipedia.Page("it","Template:Ns0").getReferences(onlyTemplateInclusion=True)
    pagineNs0=[]
    for i in p:
        if "Pagina:"+base in i.title():
            pagineNs0.append(i)
    
    datiPagine=estraiDatiLinks("Indice:"+base)
    
    for i in range(len(pagineNs0)):
        pagineNs0[i]=[eval(pagineNs0[i].title().replace("Pagina:"+base+"/","")),pagineNs0[i]]
    pagineNs0.sort()
    for i in range(len(pagineNs0)):
        pagineNs0[i]=pagineNs0[i][1]
        
    
    for i in pagineNs0:
        titolo=i.title()
        if base in titolo:
            print titolo
            testo=i.get()
            itemsNs0=produci_lista(testo,"{{Ns0","}}",1)
            for tlNs0 in itemsNs0:
                l.append([titolo,tlNs0,datiPagine[titolo][0],splittaPagina(testo)])
    if filtro:
        p=[]
        for i in l:
            if filtro in i[1]:
                p.append(i)
        l=p[:]
    
    #l=sortNs0(l,base)
    l=elaboraNs0(l)
    return l

def sortNs0(l,base):
    lo=[]
    n=1
    for i in l:
        #print i[0], base+"/","|"
        npag=find_stringa(i[0]+"|",base+"/","|")
        if npag!="":
            #print npag,
            npag=eval(npag)
            lo.append([npag,n,i])
            n+=1
    lo.sort()
    l=[]
    for i in lo:
        l.append(i[2])
    return l

def numeroPagina(pagina): # restituisce il numero di una pagina dal nome pagina
    numero=find_stringa(pagina+"##","/","##",side="rigth")
    return numero

def nomeSezione(sezione): # restituisce il nome di una section
    nome=find_stringa(sezione,"<section begin="," />").strip()
    if nome=="":
        nome=find_stringa(sezione,"<section end="," />").strip()
    if nome.startswith('"') and nome.endswith('"'):
        nome=nome[1:-1]
    return nome
    

def elaboraNs0(lista): # aggiunge vari tag a listaNs0 "grezza"
    if len(lista[0])<5:
        for i in range(len(lista)):
            lista[i]=lista[i]+["","","","","",""] # from, fromsection, to, tosection, prec, succ
    for i in  range(len(lista)):
        
        #print i,lista[i]
        segmenti=lista[i][3][1]
        ns0cor=lista[i][1]
        indexNs0=segmenti.index(ns0cor)
        paginaCorrente=numeroPagina(lista[i][0])
        if i==0:  # se si tratta del primo ns0 del libro
            lista[i][4]=paginaCorrente #carica in from il numero della pagina
            if indexNs0==1: #ed è una pagina con section
                lista[i][5]=nomeSezione(segmenti[0]) # allora carica la section begin in fromsection di ns0 corrente
                                                     # non vi sono ns0 precedenti di cui aggiornare il to / tosection
        else: # se si tratta di un ns0 successivo allora occorre aggiornare anche il to /tosection del ns0 precedente
            lista[i][4]=paginaCorrente #carica in from il numero della pagina
            if indexNs0>0:
                lista[i][5]=nomeSezione(segmenti[indexNs0-1]) # allora carica la section begin in fromsection di ns0 corrente
            if indexNs0==0 or indexNs0==1: # se ns0 è a inizio pagina allora to del ns0 precedente è numero pagina corrente -1
                lista[i-1][6]=str(eval(paginaCorrente)-1)
            else:
                lista[i-1][6]=paginaCorrente
                lista[i-1][7]=nomeSezione(segmenti[indexNs0-2])
        capCor=find_stringa(lista[i][1],"{{Ns0|","|")
        if i==0:
            lista[i][8]="../"
            lista[i][9]=abs2rel(capCor,find_stringa(lista[i+1][1],"{{Ns0|","|"))
        elif i<len(lista)-1:
            lista[i][8]=abs2rel(capCor,find_stringa(lista[i-1][1],"{{Ns0|","|"))
            lista[i][9]=abs2rel(capCor,find_stringa(lista[i+1][1],"{{Ns0|","|"))
        else:
            lista[i][8]=abs2rel(capCor,find_stringa(lista[i-1][1],"{{Ns0|","|"))

    return lista

                                              
def estraiDatiLinks(indice): # riceve da estraiPagineIndice una lista di links
   result={}
   lista=elencoPagineIndiceOld(indice,False,True)
   for i in lista:
      link=i
      qp=find_stringa(link,'class="','"')
      titolo=find_stringa(link,'title="','"')
      span=find_stringa(link,"<span","</span>",1)
      if span>"":
         link=link.replace(span,"")
      ancora=find_stringa(link,">","<")
      result[titolo]=[ancora,qp]
   return result # restituisce un vocabolario 

def elencoPagineIndiceOld(indice="Indice:Ardigo - Scritti vari.djvu",tutte=False,links=False):
    #riceve il nome di una pagina indice e estrae i dati delle pagine
    #se tutte=True, restituisce anche le pagine non esistenti
    #inizializzazione oggetto Page su pagina indice
    #site=wikipedia.getSite()
    page=wikipedia.Page("it",indice)

    # calcolo nome x url
    nomeindice="/wiki/"+page.urlname()
    
    #lettura HTML originario (prima delle alterazioni js)
    testo=leggi_pagina_html(nomeindice)
    
    #ricerca di tutti i tag <a href..>...</a> e salvataggio su file
    pagine=produci_lista(testo,'<a href="',"</a>",1)
    titoli=[]
    link=[]
    for i in pagine:
         if tutte:
           if ('title="Pagina:' in i) and ("class=" in i):
               titolo=find_stringa(i,'title="','"').replace(" (tuttora non scritto)","")
               #qp=find_stringa(i,'class="','"')
               if not titolo in titoli:
                   #elenco_pagine.append([titolo,qp])
                   titoli.append(titolo)
                   link.append(i)
         else:
            if ('title="Pagina:' in i) and ("class=" in i) and (not " (tuttora non scritto)" in i):
               titolo=find_stringa(i,'title="','"')
               if not titolo in titoli:
                  titoli.append(titolo)
                  link.append(i)
                  
   
    if links:
       risultato=link
    else:
       risultato=titoli
       

    return risultato
    
    
# riceve una lista prodotta  da listaNs0 e produce un sommario
# Al momento fornisce il titolo link alla pagina reale

def sommario(lista,addit=0):
   item=" {{Indice sommario|0|#Pagina|#Titolo|#Numero}}"
   sommario=[]
   for i in lista:
      itemc=item
      itemc=itemc.replace("#Pagina",i[0].replace("Pagina:",""))
      itemc=itemc.replace("#Numero",i[2])
      if len(i[1].split("|"))==3:
          itemc=itemc.replace("#Titolo",i[1].split("|")[2].replace("}}",""))
      else:
          np=i[1].split("|")[1].replace("}}","")
          np=np.split("/")
          titolo=np[len(np)-1]
          itemc=itemc.replace("#Titolo",titolo)
      sommario.append("*"*(i[1].count("/")+addit)+itemc)
   return "\n".join(sommario)         
            

# fornisce una lista dei testi delle pagine di un indice (elemento
#iniziale vuoto in modo che l[1]=pagina/1
def pageDownloader(base, site="it"):
   l=[]
   l.append([])
   if site=="it":
      if base.startswith("Indice:"):
         base=base.replace("Indice:","Pagina:")
      if not base.startswith("Pagina:"):
         base="Pagina:"+base
   if not base.endswith("/"):
      base+="/"
      
   n=1
   while True:
      pagina=leggi_pagina(base+str(n), site)
      if pagina=="":
         break
      l.append(splittaPagina(pagina))
      print "Caricata pagina:", base+str(n)
      n+=1
   salva_pcl(l,base.replace(".","_").replace(":","_").replace("/","_"))
   return l



      

def rc(rcstart=None,rcend=None,number=50,namespace="0|102|108|110",rcshow="!bot!redirect",rctype="edit|new"):
   ''' modulo per la lettura di number eventi da recentchanges

   Restituisce l'ultimo timestamp letto e una lista di eventi, in cui sono eliminati i doppioni (edit sulle stesse pagine).
   La lista va ulteriormente depurata dai doppioni letti nella stessa sessione (testare il valore number ideale per leggere
   l'intera lista in una sola lettura)'''
   sito=wikipedia.Site("it")
   listgen=sito.recentchanges(number=number,rcstart=rcstart,rcshow=rcshow,rctype=rctype,namespace=namespace)
   lista=[]
   for i in listgen:
      lista.append(i)

   return lista

def iw(ini,fin):
   for p in range(ini,fin):
      nomePagina="Pagina:Canti (Sole).pdf/"+str(p)
      testoPagina=leggi_pagina(nomePagina)
      header=find_stringa(testoPagina,"<noinclude><page","</noinclude>",1)
      footer=find_stringa(testoPagina,"<noinclude>\n<ref","</noinclude>",1)
      testoPagina=find_stringa(testoPagina,header,footer)
      testoPagina=testoPagina.replace(find_stringa(testoPagina,"<noinclude>","</noinclude>",1),"")
      while find_stringa(testoPagina,"<ref>","</ref>",1)!="":
         testoPagina=testoPagina.replace(find_stringa(testoPagina,"<ref>","</ref>",1),"")
      testoPagina="<section begin=1 />"+testoPagina+"<section end=1 /><noinclude>\n\n\n{{Iwpage|la|1}}</noinclude>"
      print header+testoPagina+footer
      scrivi_pagina(header+testoPagina+footer,False,nomePagina)
   return
def testAutore(autore): # autore: istanza Autore o titolo pagina Autore
   preDati='<!--non modificare da qui:--><includeonly><section begin=dati />'
   postDati='<section end=dati /></includeonly><!-- a qui-->'
   if isinstance(autore, type("stringa")):
      autore=wikipedia.Page(wikipedia.Site("it"), autore)
   autore=Autore(autore)
   #datiAttuali=find_stringa(autore.dati,preDati,postDati).split("/")
   d=find_stringa(autore.testo,preDati,postDati)
   if d=='':
      print "Autore:"+autore.nome+" "+autore.cognome+" ",
      print "La sezione dati non esiste"
      return
   else:
      d=d.split("/")
   
   modifiche=False
   campi_mod=[]
   if d[0]!=autore.nome:
      campi_mod.append("nome")
      modifiche=True
   if d[1]!=autore.cognome:
      campi_mod.append("cognome")
      modifiche=True
   if d[6]!=autore.gm_nascita:
      campi_mod.append("gm_nascita")
      modifiche=True
   if d[7]!=autore.a_nascita:
      campi_mod.append("a_nascita")
      modifiche=True
   if d[8]!=autore.gm_morte:
      campi_mod.append("gm_morte")
      modifiche=True
   if d[9]!=autore.a_morte:
      campi_mod.append("a_morte")
      modifiche=True
   if d[10]!=autore.secolo:
      campi_mod.append("secolo")
      modifiche=True
   if d[11]!=autore.secolo2:
      campi_mod.append("secolo2")
      modifiche=True
   if d[12]!=autore.prof_naz:
      campi_mod.append("prof_naz")
      modifiche=True
   if d[13]!=autore.wikipedia:
      campi_mod.append("wikipedia")
      modifiche=True
   if d[14]!=autore.wikiquote:
      campi_mod.append("wikiquote")
      modifiche=True
   if d[15]!=autore.wikinotizie:
      campi_mod.append("wikinotizie")
      modifiche=True
   if d[16]!=autore.commons:
      campi_mod.append("commons")
      modifiche=True
      
   print "Autore:"+autore.nome+" "+autore.cognome+" "   
   if not modifiche:
      print "I dati non sono stati modificati"
   else:
      print "Sono stati modificati:",
      for i in campi_mod:
         print i,
      print
      
   return 

def accoppaCapitolo(testo): # {{}}
   testo_old=testo
   testo=testo.replace("{{Capitolo","{{capitolo")
   if not "{{capitolo" in testo:
      return testo_old
   capitoli=produci_lista(testo,"{{capitolo","}}",1)
   for i in capitoli:
      testo=testo.replace(i,"")
   # estrazione parametri
   capitolo=capitoli[0]
   capitolo=capitolo.replace("|","\n|").replace("}}","\n}}")
   while " =" in capitolo:
      capitolo=capitolo.replace(" =","=")
   while "= " in capitolo:
      capitolo=capitolo.replace("= ","=")
   '''    {{Capitolo
    | CapitoloPrecedente = Titolo del capitolo predente
    | NomePaginaCapitoloPrecedente = Nome della pagina del capitolo precedente
    | CapitoloSuccessivo = Titolo del capitolo successivo
    | NomePaginaCapitoloSuccessivo = Nome della pagina del capitolo successivo
    }} '''
   '''
{{capitolo
|TitoloOpera=I Canti di Castelvecchio
|NomePaginaOpera=I Canti di Castelvecchio
|CapitoloPrecedente=La capinera
|NomePaginaCapitoloPrecedente=I Canti di Castelvecchio/La capinera
|CapitoloSuccessivo=Canzone di marzo
|NomePaginaCapitoloSuccessivo=I Canti di Castelvecchio/Canzone di marzo

}}'''
   cp=find_stringa(capitolo,"CapitoloPrecedente=","\n")
   ncp=find_stringa(capitolo,"NomePaginaCapitoloPrecedente=","\n")
   cs=find_stringa(capitolo,"CapitoloSuccessivo=","\n")
   ncs=find_stringa(capitolo,"NomePaginaCapitoloSuccessivo=","\n")
   
   testo=testo.replace("{{includiIntestazione","{{IncludiIntestazione")
   includiIntestazione=find_stringa(testo,"{{IncludiIntestazione","}}",1).replace(" =","=")
   inclnew=includiIntestazione
   if not "prec=" in includiIntestazione:
      inclnew=includiIntestazione.replace("}}","|prec="+ncp+"}}")
   if not "succ=" in includiIntestazione:
      inclnew=inclnew.replace("}}","|succ="+ncs+"}}")
   testo=testo.replace(includiIntestazione,inclnew)
   #print cp,ncp,cs,ncs
   #print testo
   return testo
      

def rcSession():
    '''legge recentchanges e produce una lista delle pagine nuove o editate

    La lettura si ferma all'edit con timestamp memorizzato in rcend.txt'''
    rcFinale=open("rcend.txt").read()
    lTitoli=[]
    lPagine=[]
    fineSerie=False
    rcIniziale=rc(number=1)[0][1]
    if rcFinale==rcIniziale:
      print "Nessuna attività nell'intervallo"
      return
    rcIn=rcIniziale
    while fineSerie==False:
      print "Leggo 50 elementi..."
      print rcIn
      lista=rc(number=50,rcstart=rcIn)
      rcIn=lista[len(lista)-1][1]
      print "Analizzo gli elementi..."
      for i in lista:
         if i[1] == rcFinale:
              fineSerie=True
              print "Trovato l'edit finale: procedo"
              break
              
         if i[0].title() in lTitoli:
             continue
         
         lTitoli.append(i[0].title())
         lPagine.append(i)
         if len(lTitoli)>1000:
            fineSerie=True
            print "Raggiunto il massimo  di pagine previsto: procedo"
            break
    print "Elaboro le pagine..."
    print "Estraggo la lista indici"
    lIndici=listaIndici(lPagine)

    for i in lPagine:
        if not i[0].namespace()==110: #indice
            elabora(i[0]) # fai qualcosa
    for i in lIndici:
        pag=wikipedia.Page("it",i)
        elabora(pag)
        

    print "Salvo il timestamp per la successiva sessione..."

    open("rcend.txt","w").write(rcIniziale)
    return

def listaIndici(listaPages):
    lIndici=[]
    for el in listaPages:
        i=el[0]
        if i.namespace()==110:
            if not i.title() in lIndici:
                lIndici.append(i.title())
        elif i.namespace()==108:
            titolo="Indice:"+find_stringa(i.title(),"Pagina:","/")
            if titolo.endswith(".djvu") or titolo.endswith(".pdf"):

        #print titolo
                if not titolo in lIndici:
                    lIndici.append(titolo)
    return lIndici

def elabora(pagina): # elemento è un oggetto pagina
    if pagina.isRedirectPage():
        return
    #print pagina,pagina.namespace()
    try:
        testoPagina = pagina.get() # Taking the text of the page
    except wikipedia.NoPage: # First except, prevent empty pages
        testoPagina = ''
        print "Pagina non esistente"
        return

    testoPaginaCorretto=testoPagina
    print "Su: ",pagina.title().encode("utf-8")," (namespace ",pagina.namespace(),")"
   
    if pagina.namespace()==108: # Ns pagina


        print "Apostrofi, ",
        testoPaginaCorretto=correggiApostrofi(testoPagina,pagina.title())

        print "infotesto, ",
        verificaInfotesto(pagina)

        print "AutoreCitato, ",
        testoPaginaCorretto=normalizzaAcPagina(testoPaginaCorretto)

        print "sections, ",
        testoPaginaCorretto=addSectionTagEngine(testoPaginaCorretto)

    


    if pagina.namespace()==0: # principale:
        print "Apostrofi, ",
        testoPaginaCorretto=correggiApostrofi(testoPagina,pagina.title())

        print "infotesto, ",
        verificaInfotesto(pagina)

        print "AutoreCitato, ",
        testoPaginaCorretto=normalizzaAcPagina(testoPaginaCorretto)
        print "conteggio pagine, ",
        testoPaginaCorretto=conteggioPagine(testoPaginaCorretto)

        print u"Qualità",
        testoPaginaCorretto=aggiungiQualita(testoPaginaCorretto)

        print "capitolo",
        testoPaginaCorretto=accoppaCapitolo(testoPaginaCorretto)

        print "tag pages/pagina"
        testoPaginaCorretto=accoppaPagina(testoPaginaCorretto)
      
    if pagina.namespace()==102: # Autore:
        print "Verifico dati",
        testAutore(pagina)

    if pagina.namespace()==110: # Indice:
        print "Verifico ",
        print u"qualità Indice"
        testoPaginaCorretto=aggiornaSalIndice(pagina.title(),testoPaginaCorretto)


    if testoPaginaCorretto!=testoPagina:
        print "Correzione"
        scrivi_pagina(testoPaginaCorretto,False,pagina.title(),commento="Correzione pagina via bot")
    return

##def qualIndice(testoPagina):
##    qd="25%"
##    qcorr=""
##    qual=find_stringa(testoPagina,u"{{Qualità|","}}",1)
##    if qual!="":
##        qcorr=find_stringa(qual,"|avz=","|")
##        testoPagina=testoPagina.replace(qual,"")
##    qcorrnew=find_stringa(testoPagina,u"|Qualità=","\n")
##    if qcorrnew=="":
##        if qcorr!="" and qcorr in ["25%","50%","75%","100%"]:
##            qcorr=qcorr
##        else:
##            qcorr=qd
##    testoPagina=testoPagina.replace(u"|Qualità=",u"|Qualità="+qcorr)
##    return testoPagina
        
        

    
def correggiApostrofi(testoPagina,nomePagina):
   if testoPagina.count("[[") != testoPagina.count("]]"):
      open("dati/errori.txt","a").write("\nSbilanciamento quadre in: "+nomePagina.encode("utf-8"))
      return testoPagina
   if testoPagina.count("{{") != testoPagina.count("}}"):
      open("dati/errori.txt","a").write("\nSbilanciamento graffe in: "+nomePagina.encode("utf-8"))
      return testoPagina
   if testoPagina.count("<") != testoPagina.count(">"):
      open("dati/errori.txt","a").write("\nSbilanciamento <> in: "+nomePagina.encode("utf-8"))
      return testoPagina
   tp=apos(testoPagina)
   tp=tp.replace("{{dot}}",u"·").replace("{{Dot}}",u"·")
   return tp

def conteggioPagine(testoPagina):
   tp=testoPagina
   if not "[[" in testoPagina:
      tp=testoPagina+"\n{{Conteggio pagine|[[Speciale:Statistiche]]}}"
   return tp
      
def verificaInfotesto(pagina):
   paginaDiscussione=pagina.toggleTalkPage()
   talkTesto=leggi_pagina(paginaDiscussione.title())
   if talkTesto=="": # la pagina discussione non esiste
      if pagina.namespace()==0: # ns0
         if "/" in pagina.title(): # sottopagina
            scrivi_pagina("{{IncludiInfotesto}}",False,paginaDiscussione.title(),commento="Aggiunta pagina discussione con IncludiInfotesto")
            print "Aggiunto infotesto a ",paginaDiscussione.title()
                     
      elif pagina.namespace() == 108: # ns Pagina
         scrivi_pagina("{{IncludiInfotesto}}",False,paginaDiscussione.title(),commento="Aggiunta pagina discussione con IncludiInfotesto")
         print "Aggiunto infotesto a ",paginaDiscussione.title()
   return

def apos(p=""):
    if p=="":

        p='''prova ''test'' <test1> prova' test {{test2<br />}} prova test
<test1> prova test [[test3' {{test2' <br />}} ]]
prova [test4] prova' http://www.alex'.com prova '''
    lista=[]
    p1=p[:]
    ne=0
    l=produci_lista(p1,u"<math>",u"</math>",1)
    for r in l:
        if not r in lista:
            el="#e"+str(ne)+"#"
            lista.append((r,el))
            p1=p1.replace(r,el)
            ne=ne+1
            #print "math",ne,

    #print
    l=produci_lista(p1,u"{{{",u"}}}",1)
    for r in l:
        if not r in lista:
            el="#e"+str(ne)+"#"
            lista.append((r,el))
            p1=p1.replace(r,el)
            ne=ne+1
            #print "templ",ne,
    #print
    l=produci_lista(p1,u"<",u">",1)
    for r in l:
        if not r in lista:
            el="#e"+str(ne)+"#"
            lista.append((r,el))
            p1=p1.replace(r,el)
            ne=ne+1
            #print "html",ne,
    #print "<>"
    l=produci_lista(p1,u"[[",u"]]",1)
    for r in l:
        if not r in lista:
            el="#e"+str(ne)+"#"
            lista.append((r,el))
            p1=p1.replace(r,el)
            ne=ne+1
            #print "wlink",ne,
    #print "[[]]"
            
    l=produci_lista(p1,u"[",u"]",1)
    for r in l:
        if not r in lista:
            el="#e"+str(ne)+"#"
            lista.append((r,el))
            p1=p1.replace(r,el)
            ne=ne+1
            #print "link1",ne,
    #print "[]"
    l=produci_lista(p1,u"http://",u" ",1)
    for r in l:
        if not r in lista:
            el="#e"+str(ne)+"#"
            lista.append((r,el))
            p1=p1.replace(r,el)
            ne=ne+1
            #print "link2",ne,
    #print "http:"
    l=produci_lista(p1,u"{{",u"}}",1)
    for r in l:
        if not r in lista:
            el="#e"+str(ne)+"#"
            lista.append((r,el))
            p1=p1.replace(r,el)
            ne=ne+1
            #print "templ",ne,
    #print u"{{}}"
    #return p1
    if "'''" in p1:
        p1=p1.replace("'''","#ebold#")
        lista.append(("'''","#ebold#"))
    if "''" in p1:
        p1=p1.replace("''","#eitalic#")
        lista.append(("''","#eitalic#"))
    if not "'" in p1:
        #non vi sono apostrofi tipografici nel testo modificabile,
        #la stringa viene restituita immutata
        return p                  
    #qui modificare p1
    
    p1=p1.replace(u"'",u"’")
##    p1=p1.replace(u"’’’",u"'''")
##    p1=p1.replace(u"’’",u"''")

    lista.reverse()
    p2=p1[:]
    for r in lista:
        p2=p2.replace(r[1],r[0])
        #print r[1],r[0]

    return p2

# estrai lista pagine di un ns (default:102, Autore)
def listaPagine(ns=102,includeredirects=False):
   lista=[]
   lpg=pagegenerators.AllpagesPageGenerator(namespace=102,includeredirects=includeredirects)
   for i in lpg:
      lista.append(i)
   return lista
   
def templateR(ini=79,fin=85,test=False,versoIniziale=0,basePagina="Pagina:Canti (Sole).pdf/xxx"):
   
   nv=versoIniziale
   if nv>0:
      versi=True
   else:
      versi=False
   spaziatura={}
   cancella=False
   for i in range(ini,fin):
      nomePagina=basePagina.replace("xxx",str(i))
      testoPagina=leggi_pagina(nomePagina)
      testoPagina=testoPagina.replace("<!-- no verso-->","<!-- no verso -->")
      rigaPagina=testoPagina.split("\n")
      versiPagina=rigaPagina[:]
      for i in range(len(versiPagina)):
         versiPagina[i]=""
      # algoritmo riconoscimento versi
      for r in range(len(versiPagina)):
         if "<!-- schema" in rigaPagina[r]:
            sch=find_stringa(rigaPagina[r],"<!-- schema","-->").split(";")
            for i in sch:
               el=i.split(":")
               if len(el)==1:
                  spaziatura["l"]=eval(el[0])
               else:
                  spaziatura[eval(el[0])]=eval(el[1])
            print spaziatura
            
         if not versi:
##            if "<!-- inizio versi -->" in rigaPagina[r].lower():
##               
##               versi=True
            if "<!-- inizio poesia -->" in rigaPagina[r].lower():
               cancella=True
               versi=True
               versiPagina[r]="*"
            else:
               continue

         if versi:
            if cancella:
               rigaPagina[r]=rigaPagina[r].lstrip()
               rigaPagina[r]=rigaPagina[r].replace(find_stringa(rigaPagina[r],"{{R|","}}",1),"")
            rp=rigaPagina[r].replace("<poem>","").replace("</poem>","")
            rp=rp.replace("<noinclude>","").replace("</noinclude>","")
            rp=rp.strip()
            
            if rp==u"":
               continue
            elif "<!-- no verso -->" in rigaPagina[r].lower():
               continue
            elif "{{centrato" in rigaPagina[r].lower():
               continue
            elif "pagequality" in rigaPagina[r].lower():
               continue
            elif "references" in rigaPagina[r].lower():
               continue
            else:
               versiPagina[r]+="*"
               if "<!-- fine versi -->" in rigaPagina[r].lower():
                  versi=False
      for r in range(len(versiPagina)):
         if versiPagina[r]=="**":
            nv=1
            if "l" in spaziatura and (nv-1) % spaziatura["l"] in spaziatura:
               rigaPagina[r]=" "*spaziatura[(nv-1) % spaziatura["l"]]+rigaPagina[r].lstrip()
         elif versiPagina[r]=="*":
            nv=nv+1
            if "l" in spaziatura and (nv-1) % spaziatura["l"] in spaziatura:
               rigaPagina[r]=" "*spaziatura[(nv-1) % spaziatura["l"]]+rigaPagina[r].lstrip()
            if nv % 5 ==0:
               if "</poem>" in rigaPagina[r]:
                  rigaPagina[r]=rigaPagina[r].replace("</poem>","{{R|##}}".replace("##",str(nv)))
               else:
                  rigaPagina[r]=rigaPagina[r].rstrip()+"{{R|##}}".replace("##",str(nv))
         print versiPagina[r],rigaPagina[r]
      testoPagina="\n".join(rigaPagina)
      testoPagina=testoPagina.replace("<!-- inizio poesia -->","")\
.replace("<!-- inizio versi -->","").replace("<!-- fine versi -->","")
      #print testoPagina
      if not test:
         scrivi_pagina(testoPagina,False,nomePagina)
   return
         
         
              
            

def correggiPoem(pagina):
   testoPagina=leggi_pagina(pagina)
   testoPagina=testoPagina.replace("<poem> \n","<poem>").replace("\n</poem>","</poem>")
   scrivi_pagina(testoPagina,False,pagina,commento="Normalizzazione tag poem via bot")
   return

def chiamaCorreggiPoem(basePagina):
   numeroPagina=1
   while True:
      pagina=basePagina+str(numeroPagina)
      testoPagina=leggi_pagina(pagina)
      if testoPagina=="":
         print "Fine controllo"
      if "<poem> \n" in testoPagina or "\n</poem>"in testoPagina:
         correggiPoem(pagina)
         numeroPagina+=1
      else :
         print "Pagina", pagina, "non contiene tag poem"
         numeroPagina+=1
         
   return
   
      
   
def aggiungiQualita(testo):
    if not u"{{Qualità" in testo:
        testo=u"{{Qualità|avz=25%|data=|arg=Da definire}}"+testo
    return testo
   
   
   
def correggiSAL():
   lista=produci_lista(leggi_pagina("Wikisource:Pagina delle prove"),"{{testo|","}}")
   for i in lista:
      if "Sonetti romaneschi" in i:
         testo=leggi_pagina(i)
         testo=testo.replace(find_stringa(testo,u"{{Qualità|avz=25%|","}}",1),"")
         scrivi_pagina(testo,False,i)
   return 
                       
def caricaLibro(folder="dati/bemcav", baseFile="bemcavalgar-singlepages - ", \
                zf=4, basePagina=u"Página:Bem cavalgar (1842).djvu/#", ini=1,fin=1,poem=False,code="pt"):
   base=u'<noinclude><pagequality level="1" user="Alebot" /><div class="pagetext">\n\n\n</noinclude>#<noinclude>\n<references/></div></noinclude>'
   for pag in range(ini,fin+1):
      pagina=open(folder+"/"+baseFile+str(pag).zfill(zf)+".txt").read()
      pagina=unicode(pagina,"utf-8")
      if poem:
         pagina="<poem> \n"+pagina+"</poem>"
      nomePagina=basePagina.replace("#",str(pag))
      if leggi_pagina(nomePagina)!="":
         pagina=base.replace("#",pagina)
      scrivi_pagina(pagina,False,nomePagina, commento="External upload/edit by unflagged bot",code=code)
      
   return

def recentchanges(number = 200, rcstart = None, rcdir="newer",
      rcend = None, rcshow = None, rctype ='edit|new', namespace="0|102|108|110", 
      includeredirects=False, repeat = False):
   # chiama il metodo recentchanges() di wikipedia.Site()
   # produce un generatore che restituisce la seguente tuple di esempio:
   # (Page{[[Poema paradisiaco/Hortus Larvarum]]}, u'2010-04-25T08:23:24Z',
   # u'LloydApplebaum', u'Porto il SAL a SAL 75%', '')
   # ossia: page, i['timestamp'], i['user'], comment, loginfo
   
   rcstart=carica_pcl("rcstart")
      
   """def recentchanges(self, number = 100, rcstart = None,
      rcend = None, rcshow = None, rctype ='edit|new', namespace=None,
      includeredirects=True, repeat = False):
        
        Yield ImagePages from APIs, call: action=query&list=recentchanges&rctype=edit|new&rclimit=500

        Options directly from APIs:
        ---
        Parameters:
          rcstart        - The timestamp to start enumerating from.
          rcend          - The timestamp to end enumerating.
          rcdir          - In which direction to enumerate.
                           One value: newer, older
                           Default: older
          rcnamespace    - Filter log entries to only this namespace(s)
                           Values (separate with '|'):
                           0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15
          rcprop         - Include additional pieces of information
                           Values (separate with '|'):
                           user, comment, flags, timestamp, title, ids, sizes,
                           redirect, patrolled, loginfo
                           Default: title|timestamp|ids
          rctoken        - Which tokens to obtain for each change
                           Values (separate with '|'): patrol
          rcshow         - Show only items that meet this criteria.
                           For example, to see only minor edits done by
                           logged-in users, set show=minor|!anon
                           Values (separate with '|'):
                           minor, !minor, bot, !bot, anon, !anon,
                           redirect, !redirect, patrolled, !patrolled
          rclimit        - How many total changes to return.
                           No more than 500 (5000 for bots) allowed.
                           Default: 10
          rctype         - Which types of changes to show.
                           Values (separate with '|'): edit, new, log"""
   source=wikipedia.Site("it")
   rctype="new"
   tnew=t
   tedit=t
   pagineRecentiNuove=source.recentchanges(number, rcstart , rcend,  rcshow, rcdir,  rctype, namespace, includeredirects, repeat)
   lnew=[]
   for i in pagineRecentiNuove:
      lnew.append(i)
   if len(lnew)>0:
      tnew=lnew[len(lnew)-1][1]
   rctype="edit"
   rcshow="!bot|!redirect"
   pagineRecentiEdit=source.recentchanges(number, rcstart , rcend,  rcshow, rcdir,  rctype , namespace, includeredirects, repeat)
   ledit=[]
   for i in pagineRecentiEdit:
      ledit.append(i)
   if len(ledit)>0:
      tedit=ledit[len(ledit)-1][1]
   salva_pcl(max(tnew,tedit),"rcstart")
      
   return lnew,ledit



   
           
         
      
   
def listaCapitoli(pagina,doElabora=False): #pagina è il nome di una pagina o sottopagina Ns0
   if "/" in pagina:
      pagina=find_stringa("##"+pagina,"##","/")
   pag=leggi_pagina(pagina)
   pag=pag.replace("{{Testo","{{testo")
   lista=produci_lista(pag, "{{testo|","}}")
   for i in range(len(lista)):
      if "|" in lista[i]:
         lista[i]=lista[i][:lista[i].find("|")]
      if lista[i].startswith("/"):
         lista[i]=pagina+lista[i]
   if doElabora:
      for i in lista:
         oggettoPagina=wikipedia.Page("it",i)
         elabora(oggettoPagina)
   return lista

   
      

def rs(elenco):
   for i in elenco:
      rivediSottopagine(i)
   return

def rivediSottopagine(pagina,commento="Correzione tag poem"):
   pag=leggi_pagina(pagina)
   pag=pag.replace("{{Testo","{{testo")
   lista=produci_lista(pag, "{{testo|","}}")
   for i in range(len(lista)):
      if "|" in lista[i]:
         lista[i]=lista[i][:lista[i].find("|")]
      if lista[i].startswith("/"):
         lista[i]=pagina+lista[i]
   for sottopagina in lista:
      testo=leggi_pagina(sottopagina)
      if testo>"":
         # azione da fare sulle sottopagine
         testo1=modifica(testo,sottopagina)
         if testo1!=testo:
            scrivi_pagina(testo1,False,sottopagina,commento=commento)
   
         
         
   return 

def modifica(testo,sottopagina):
   if "<poem>\n" in testo:
      testo=testo.replace("<poem>\n","<poem> \n")
   else:
      print sottopagina,"OK"
   # altre azioni...
   return testo


def nuovePagineTest():
   np=[]
   npag=pagegenerators.NewpagesPageGenerator(number=10,namespace=0)
   for i in npag:
      np.append(i)
   return np

schemaDatiAutore='''
<includeonly>{{{{{2|Autore}}}
 0   | Nome ={{#titleparts:{{#section:Autore:{{{1|Giacomo Leopardi}}}|dati}}|1|1}}
 1   | Cognome ={{#titleparts:{{#section:Autore:{{{1|Giacomo Leopardi}}}|dati}}|1|2}}
 2   | Iniziale del cognome ={{#titleparts:{{#section:Autore:{{{1|Giacomo Leopardi}}}|dati}}|1|3}}
 3   | Eventuale altro nome ={{#titleparts:{{#section:Autore:{{{1|Giacomo Leopardi}}}|dati}}|1|4}}
 4   | Eventuale pseudonimo ={{#titleparts:{{#section:Autore:{{{1|Giacomo Leopardi}}}|dati}}|1|5}}
 5   | Eventuale nome reale ={{#titleparts:{{#section:Autore:{{{1|Giacomo Leopardi}}}|dati}}|1|6}}
 6   | Giorno e mese di nascita ={{#titleparts:{{#section:Autore:{{{1|Giacomo Leopardi}}}|dati}}|1|7}}
 7   | Anno di nascita ={{#titleparts:{{#section:Autore:{{{1|Giacomo Leopardi}}}|dati}}|1|8}}
 8   | Giorno e mese di morte ={{#titleparts:{{#section:Autore:{{{1|Giacomo Leopardi}}}|dati}}|1|9}}
 9   | Anno di morte ={{#titleparts:{{#section:Autore:{{{1|Giacomo Leopardi}}}|dati}}|1|10}}
 10   | Secolo di attività ={{#titleparts:{{#section:Autore:{{{1|Giacomo Leopardi}}}|dati}}|1|11}}
 11   | Eventuale secondo secolo di attività ={{#titleparts:{{#section:Autore:{{{1|Giacomo Leopardi}}}|dati}}|1|12}}
 12   | Professione e nazionalità ={{#titleparts:{{#section:Autore:{{{1|Giacomo Leopardi}}}|dati}}|1|13}}
 13   | Nome della pagina su Wikipedia ={{#titleparts:{{#section:Autore:{{{1|Giacomo Leopardi}}}|dati}}|1|14}}
 14   | Nome della pagina su Wikiquote ={{#titleparts:{{#section:Autore:{{{1|Giacomo Leopardi}}}|dati}}|1|15}}
 15   | Nome della pagina su Wikinotizie ={{#titleparts:{{#section:Autore:{{{1|Giacomo Leopardi}}}|dati}}|1|16}}
 16   | Nome della pagina su Commons ={{#titleparts:{{#section:Autore:{{{1|Giacomo Leopardi}}}|dati}}|1|17}}
 17   | Nome dell'immagine ={{#titleparts:{{#section:Autore:{{{1|Giacomo Leopardi}}}|dati}}|1|18}}
 18   | Vuoi l'indice dei contenuti? ={{#titleparts:{{#section:Autore:{{{1|Giacomo Leopardi}}}|dati}}|1|19}}
 19   | Abbiamo testi scritti dall'autore? ={{#titleparts:{{#section:Autore:{{{1|Giacomo Leopardi}}}|dati}}|1|20}}
 20   | Abbiamo traduzioni scritte dall'autore? ={{#titleparts:{{#section:Autore:{{{1|Giacomo Leopardi}}}|dati}}|1|21}}
 21   | L'autore è citato in altre opere pubblicate? ={{#titleparts:{{#section:Autore:{{{1|Giacomo Leopardi}}}|dati}}|1|22}}
    }}</includeonly>'''



class Autore(wikipedia.Page): # Acquisisce tutti i metodi di Site
   def __init__(self, pagina):      # nota: pagina è già un'istanza di Page, me la passa pagegenerators.py
      self.testo=pagina.get()       # e infatti, i suoi  metodi funzionano, compreso get
      if "{{Autore" in self.testo:
         self.intestazione=find_stringa(self.testo,"{{Autore","}}",1)   # find_stringa è una funzione mia (la mia prediletta...)
                                                                                            # fa una cosetta che con le regex si impazzirebbe.... almeno io.
      else:
         self.intestazione=find_stringa(self.testo,"{{autore","}}",1)
      intStandard=self.intestazione.replace("| ","|").replace(" =","=") # una sistemata a eventuali varianti di spazi
      self.intStandard=intStandard                                                                # questo è un  print di debug
      self.page=pagina
      self.nome=find_stringa(intStandard,u"|Nome=","\n").strip()
      self.cognome=find_stringa(intStandard,u"|Cognome=","\n").strip()
      self.iniziale=find_stringa(intStandard,u"|Iniziale del cognome=","\n").strip()
      self.altro_nome=find_stringa(intStandard,u"|Eventuale altro nome=","\n").strip()
      self.pseudonimo=find_stringa(intStandard,u"|Eventuale pseudonimo=","\n").strip()
      self.nome_reale=find_stringa(intStandard,u"|Eventuale nome reale=","\n").strip()
      self.gm_nascita=find_stringa(intStandard,u"|Giorno e mese di nascita=","\n").strip()
      self.a_nascita=find_stringa(intStandard,u"|Anno di nascita=","\n").strip()
      self.gm_morte=find_stringa(intStandard,u"|Giorno e mese di morte=","\n").strip()
      self.a_morte=find_stringa(intStandard,u"|Anno di morte=","\n").strip()
      self.secolo=find_stringa(intStandard,u"|Secolo di attività=","\n").strip()
      self.secolo2=find_stringa(intStandard,u"|Eventuale secondo secolo di attività=","\n").strip()
      self.prof_naz=find_stringa(intStandard,u"|Professione e nazionalità=","\n").strip()
      self.wikipedia,self.wikiquote,self.wikinotizie,self.commons,self.immagine="","","","",""
      if find_stringa(intStandard,u"|Nome della pagina su Wikipedia=","\n").strip()!="":
         self.wikipedia="x"
      if find_stringa(intStandard,u"|Nome della pagina su Wikiquote=","\n").strip()!="":
         self.wikiquote="x"
      if find_stringa(intStandard,u"|Nome della pagina su Wikinotizie=","\n").strip()!="":
         self.wikinotizie="x"
      if find_stringa(intStandard,u"|Nome della pagina su Commons=","\n").strip()!="":
         self.commons="x"
      if find_stringa(intStandard,u"|Nome dell'immagine=","\n").strip()!="":
         self.immagine="x"
      self.indice=find_stringa(intStandard,u"|Vuoi l'indice dei contenuti?=","\n").strip()         
      self.testi=find_stringa(intStandard,u"|Abbiamo testi scritti dall'autore?=","\n").strip()
      self.traduzioni=find_stringa(intStandard,u"|Abbiamo traduzioni scritte dall'autore?=","\n").strip()
      self.citazioni=find_stringa(intStandard,u"|L'autore è citato in altre opere pubblicate?=","\n").strip()
      self.dati="<!--non modificare da qui:--><includeonly><section begin=dati />"+\
self.nome+"/"+self.cognome+"/"+self.iniziale+"/"+self.altro_nome+"/"+self.pseudonimo+"/"+\
self.nome_reale+"/"+self.gm_nascita+"/"+self.a_nascita+"/"+\
self.gm_morte+"/"+self.a_morte+"/"+self.secolo+"/"+self.secolo2+"/"+self.prof_naz+"/"+\
self.wikipedia+"/"+self.wikiquote+"/"+self.wikinotizie+"/"+self.commons+"/"+\
self.immagine+"/"+self.indice+"/"+self.testi+"/"+self.traduzioni+"/"+self.citazioni+\
"<section end=dati /></includeonly><!-- a qui-->\n"
   def autore_per_indici(self): # usa nome,cognome,gm_nascita,a_nascita,gm_morte,a_morte,prof_naz
      riga="<tr><td>'''''[[Autore:"+self.nome
      if self.cognome!="":
         riga+="_"+self.cognome
      riga+="|"
      if self.cognome=="":
         riga+=self.nome
      else:
         riga+=self.cognome+",&nbsp;"+self.nome
      riga+="]]'''''</td>"
      if self.a_nascita=="":
         if self.a_morte=="":
            if self.secolo=="":
               riga+="<td>&nbsp;</td>"
            else:
               riga+="<td>"+self.secolo+"</td>"
         else:
            if self.gm_morte=="":
               riga+=u"<td>????&nbsp;–&nbsp;"+self.a_morte+"</td>"
            else:
               riga+=u"<td>????&nbsp;–&nbsp;{{DataGiorno|"+self.gm_morte+"}}&nbsp;"+self.a_morte+"</td>"
      else:
         if self.a_morte=="":
            if self.gm_nascita=="":
               riga+="<td>"+self.a_nascita+u"&nbsp;–&nbsp;...</td>"
            else:
               riga+="{{DataGiorno|"+self.gm_nascita+u"}}&nbsp;"+self.a_nascita+u"&nbsp;–&nbsp;...</td>"
         else:
            if self.gm_morte=="":
               if self.gm_nascita=="":
                  riga+="<td>"+self.a_nascita+u"&nbsp;–&nbsp;"+self.a_morte+"</td>"
               else:
                  riga+="<td>{{DataGiorno|"+self.gm_nascita+"}}&nbsp;"+self.a_nascita+u"&nbsp;–&nbsp;"+self.a_morte+"</td>"
            else:
               if self.gm_nascita=="":
                  riga+="<td>"+self.a_nascita+u"&nbsp;–&nbsp;{{DataGiorno|"+self.gm_morte+u"}}&nbsp;"+self.a_morte+"</td>"
               else:
                  riga+="<td>{{DataGiorno|"+self.gm_nascita+"}}&nbsp;"+self.a_nascita+\
                     u"&nbsp;–&nbsp;{{DataGiorno|"+self.gm_morte+"}}&nbsp;"+self.a_morte+"</td>"
      if self.prof_naz=="":
         riga+=u"<td>&nbsp;</td>"
      else:
         riga+="<td>{{lcfirst:"+self.prof_naz+"}}</td>"
      riga+="</tr>"
      return riga
   def autore_per_indici_new(self): # usa nome,cognome,gm_nascita,a_nascita,gm_morte,a_morte,prof_naz
      riga="<tr><td>'''''[[Autore:"+self.nome
      if self.cognome!="":
         riga+="_"+self.cognome
      riga+="|"
      if self.cognome=="":
         riga+=self.nome
      else:
         riga+=self.cognome+",&nbsp;"+self.nome
      riga+="]]'''''</td>" # cella 1
      if self.gm_nascita!="":
         riga+="<td>[[Wikisource:Ricorrenze/"+self.gm_nascita+"|"+ self.gm_nascita+"]]</td>"
      else:
         riga+="<td>&nbsp;</td>"
      if self.a_nascita!="":
         riga+="<td>"+self.a_nascita+"</td>"
      else:
         riga+="<td>&nbsp;</td>"
      if self.gm_morte!="":
         riga+="<td>[[Wikisource:Ricorrenze/"+self.gm_morte+"|"+ self.gm_morte+"]]</td>"
      else:
         riga+="<td>&nbsp;</td>"
      if self.a_nascita!="":
         riga+="<td>"+self.a_morte+"</td>"
      else:
         riga+="<td>&nbsp;</td>"
      if self.a_nascita!="":
         riga+="<td>"+self.secolo+"</td>"
      else:
         riga+="<td>&nbsp;</td>"
      if self.prof_naz!="":
         riga+="<td>"+self.prof_naz+"</td></tr>\n"
      else:
         riga+="<td>&nbsp;</td></tr>\n"
      return riga


def ritorna():
   return



   

def leggiNuovePagine(lnew,ledit):
   for ns in ["Autore","Principale","Pagina","Indice"]: # :["Pagina"]
      #np=nuovePagine(nPag=200, ns=ns, repeat=False)
      np=[]
      for i in lnew:
         if i[0].namespace()==wnamespaces[ns]:
            np.append(i[0])
            
      if len(np)>0:
         azioniNuovePagine(np,ns)
         
      else:
         print "Nessuna nuova pagina ", ns
##      ep=[]
##      for i in ledit:
##         if i[0].namespace()==wnamespaces[ns]:
##            ep.append(i[0])
##            
##      if len(np)>0:
##         azioniPagineEditate(ep,ns)
##         
##      else:
##         print "Nessuna pagina editata", ns
##         
   print "Numero delle pagine editate: ", len(ledit)
   return

def azioniNuovePagine(np,ns):
   print "Nuove pagine ",len(np)
   for i in np:

      print i.title()
      if ns=="Pagina":
         titleDiscussione=i.title().replace("Pagina:","Discussioni pagina:")
         print titleDiscussione
         if leggi_pagina(titleDiscussione)=="":
            scrivi_pagina("{{IncludiInfotesto}}",False,titleDiscussione,commento="Aggiunta tl IncludiInfotesto via bot")
      elif ns=="Principale":
         if not "/" in i.title():
            testo=i.get().replace("{{Raccolta","{{raccolta")
            raccolta=find_stringa(testo,"{{raccolta|","}}")
            #print raccolta
            if not raccolta=="":
            
               if leggi_pagina("Discussione:"+raccolta) != "":
                  pagDiscussione="Discussione:"+i.title()
                  if leggi_pagina(pagDiscussione) == "":
                  #print "Scriverò su", pagDiscussione, "{{Discussione:"+raccolta+"}}"
                     scrivi_pagina("{{Discussione:"+raccolta+"}}",False,pagDiscussione)
                  else:
                     print pagDiscussione, "esistente"
   return

def azioniPagineEditate(np,ns):
   print "Pagine editate ",len(np)
   for i in np:

      print i.title()

      if ns=="Pagina" or ns=="Principale":
         testoPagina=i.get()
         tp=apos(testoPagina)
         if tp != testoPagina:
            scrivi_pagina(tp,False,i.title(),commento="Correzione apostrofi via bot")
   return
               
                  

def nuovePagine(nPag=200, ns="Autore",repeat=False):
    nsn=wnamespaces[ns]
    #NewpagesPageGenerator(number = 100, get_redirect = False, repeat = False, site = None, namespace = 0):
    npag=pagegenerators.NewpagesPageGenerator(number=nPag,namespace=nsn)
    vecchiePagine=carica_pcl("nuove"+ns)
    nuovePagine=[]
    np=set('')
    for i in npag:
        if not i.title() in vecchiePagine:
            np.add(i)
            nuovePagine.append(i.title())
    if len(nuovePagine)>0:
        vecchiePagine=vecchiePagine+nuovePagine
        if len(vecchiePagine)>500:
            vecchiePagine=vecchiePagine[-500:]
        salva_pcl(vecchiePagine, "nuove"+ns)
        print "Salvato nuovo elenco ","nuove"+ns, "di",len(vecchiePagine),"elementi"
        
    return np

def richieste_bot():
    pr=list_in_cat("Bot calls")
    print pr
    if len(pr)>0:
        pagina=pr[0]
        testo_pagina=leggi_pagina(pagina)
        richiesta=find_stringa(testo_pagina,"{{ToAlebot","}}",1)
        #testo_pagina=testo_pagina.replace(richiesta,"")
        #scrivi_pagina(testo_pagina,False,pagina)
        risultato=esegui_richiesta(richiesta,pagina)
        print "Richiesta eseguita"
    else:
        print "Nessuna richiesta pendente"
    return 

def esegui_richiesta(richiesta,pagina_richiesta):
    r=find_stringa(richiesta,"{{ToAlebot","}}").split("|")
    r_user=""
    r_page=""
    
    for i in range(len(r)):
        if r[i].lower().startswith("user="):
            r_user=r[i]
        if r[i].lower().startswith("page="):
            r_page=r[i]
    rx=r[:]
    r=[]
    for i in rx:
        if i!= r_user and i!=r_page:
            r.append(i)
    print "Richiesta da eseguire:",r[0]

    ## routine intersection
    if r[0].lower()=="intersection":
        intersection(richiesta,pagina_richiesta,r,r_user,r_page)
    elif r[0].lower()=="agginfotesto":
        aggiungiInfotesto(richiesta,pagina_richiesta,r, r_user,r_page)
    else:
        print "Richiesta non comprensibile"

    return

def aggiungiInfotesto(richiesta,pagina_richiesta,r, r_user,r_page):
    aggInfotesto()
    testoPaginaRichiesta=leggi_pagina(pagina_richiesta).replace(richiesta,"")
    scrivi_pagina(testoPaginaRichiesta,False,pagina_richiesta, commento="Cancellata la richiesta ToAlebot via bot")
    
    return

def aggInfotesto():
    lista=list_in_cat("Pagine senza pagina di discussione")
    print "Numero pagine: ",len(lista)
    for i in lista:
        #print i
        if "/" in i:
            testoDiscussione=leggi_pagina("Discussione:"+i)
            testoPagina=leggi_pagina(i)
            
            if testoDiscussione=="":
                scrivi_pagina("{{IncludiInfotesto}}",False,"Discussione:"+i,commento="Aggiunto tl IncludiInfoTesto via bot")
            
            if not "[[" in testoPagina:
                scrivi_pagina("\n{{Conteggio pagine|[[Speciale:Statistiche]]}}",True,i,commento="Aggiunto tl ConteggioPagine via bot")
            elif testoDiscussione !="":
                scrivi_pagina(testoPagina, False,i,commento="Forzatura aggiornamento Categoria")
    return

def intersection(richiesta,pagina_richiesta,r, r_user,r_page):
    print r
    lista='''\n===Risultato query: intersezione categorie===\nDalla intersezione di '''
    info=r[1:]
    for i in range(len(info)):
        info[i]=" '''"+info[i]+"''' "
    lista+="&".join(info)
    lista+= "\nrisulta il seguente elenco di pagine:\n"
    lista_pagine=query(r)
    for i in lista_pagine:
        lista+="* {{testo|"+i+"}}\n"
    if r_page=="":
        pagina_risposta="Wikisource:Pagina delle prove"
    if pagina_risposta==pagina_richiesta:
        testoPaginaRisposta=leggi_pagina(pagina_richiesta).replace(richiesta,lista)
        #print testoPaginaRisposta
        scrivi_pagina(testoPaginaRisposta,False,pagina_risposta,commento="Scrittura risposta query intersection via bot")
    else:
        print "pagina risposta:",pagina_risposta
        scrivi_pagina(lista,True,pagina_risposta,commento="Scrittura risposta query intersection via bot")
        testoPaginaRichiesta=leggi_pagina(pagina_richiesta).replace(richiesta,"")
        scrivi_pagina(testoPaginaRichiesta,False,pagina_richiesta,commento="Cancellazione richiesta query intersection via bot")
    return

def query(r):
    print r
    l=set(list_in_cat(r[1])) # estrazione dati prima categoria
    print r[1], len(l)
    for i in range(2,len(r)): # estrazione dati altre categorie e intersezione con la prima
        c=set(list_in_cat(r[i]))
        print r[i], len(c)
        l=l & c
    ls=[]
    for i in l:
        ls.append(i)
    ls.sort()
##    s=u""
##    for i in ls:
##        s=s+"* {{testo|"+i+"}}\n"
    return ls # restituisce la lista delle pagine

class MailBot:
    def __init__(self, destinationUser, subject, message, copyToMe):
        self.destinationUser = destinationUser
        self.subject = subject
        self.message = message
        self.copyToMe = copyToMe

        # valido per it.wikisource (servirebbe una lista da cui scegliere secondo wikipedia.getSite() ...)
        self.sendEmailPage = "/wiki/Speciale:InviaEMail/" 
        self.sendEmailPagePOST = "/w/index.php?title=Speciale:InviaEMail&target=%s&action=submit" 

    def run(self):
        # get any page to get token parameter
        mailToPage = wikipedia.getSite().getUrl(self.sendEmailPage + self.destinationUser)
        token=find_stringa(mailToPage,u'<input name="wpEditToken" type="hidden" value="','"')
        print token 
        if token=="":
            print "Fail: token not found"
            return

        # create post parameters
        subject = self.subject.encode(wikipedia.getSite().encoding())
        message = self.message.encode(wikipedia.getSite().encoding())
        if self.copyToMe:
            copyToMe = '1'
        else:
            copyToMe = '0'
        predata = {
            'wpSubject': subject,
            'wpText': message,
            'wpCCMe': copyToMe,
            'wpEditToken' : token
        }

        # do a post request
        postUrl = self.sendEmailPagePOST % self.destinationUser
        response, data = wikipedia.getSite().postForm(postUrl, predata)
        
        if response.status == 302: # redirect code
            print "Mail (probably) sent"
        else:
            print "Fail: http status code is %s, error reason is %s" % (str(response.status), response.reason)


def mailto(utente=u"Alex_brollo",oggetto=u"Prova invio",messaggio=u"Testo messaggio prova", cc=False ):
	bot = MailBot(utente, oggetto, messaggio, cc)
	bot.run()



def oggi():
    oggi=date.today()
    oggi=oggi.isoformat().split("-")
    print oggi
    mesi=["gennaio","febbraio","marzo","aprile","maggio","giugno", "luglio","agosto","settembre","ottobre","novembre","dicembre"]
    mese=oggi[1]
    if mese.startswith("0"):
        mese=mese[1:]
    mese=eval(mese)-1
    oggi=oggi[2] +" "+ mesi[mese] +" "+oggi[0]
    return oggi





def list_in_cat(category_name,site="it"):
    site = wikipedia.getSite()
    cat = catlib.Category(site,'Category:'+category_name)
    gen = pagegenerators.CategorizedPageGenerator(cat)
    page_list=[]
    for page in gen:
    #Do something with the page object, for example:
        page_list.append(page.title())
    return page_list

      
def sposta_pagina(nome_pagina,nuovo_nome_pagina,motivo):
    site = wikipedia.getSite()
    page = wikipedia.Page(site, nome_pagina)
    try:
        text = page.move(nuovo_nome_pagina,reason=motivo,
      throttle=False, deleteAndMove=False, safe=True, fixredirects=False, leaveRedirect=False) # Taking the text of the page
    except wikipedia.NoPage: # First except, prevent empty pages
        text = ''
    except wikipedia.IsRedirectPage: # second except, prevent redirect
        text = "#REDIRECT"
        # output(u'%s is a redirect!' % pagename)
        
    except wikipedia.Error: # third exception, take the problem and print
        output(u"Some error, skipping..")
    #wikipedia.stopme()
    return text
   
   
                      
def leggi_pagina(nome_pagina=u"Utente:Alex brollo",site="it"):
    #site = wikipedia.getSite()
    page = wikipedia.Page(site, nome_pagina)
    try:
        text = page.get() # Taking the text of the page
    except wikipedia.NoPage: # First except, prevent empty pages
        text = ''
    except wikipedia.IsRedirectPage: # second except, prevent redirect
        text = "#REDIRECT"
        # output(u'%s is a redirect!' % pagename)
        
    except wikipedia.Error: # third exception, take the problem and print
        output(u"Some error, skipping..")
    #wikipedia.stopme()
    return text
                  

# Writes into it.wikisource a unicode string into a named page (full name), adding to previous content (aggiungi=True)
# or replacing it (aggiungi=False)
def scrivi_pagina(testo="",aggiungi=True,nome_pagina="Utente:Alex brollo/Sandbox",commento="Edit by Alebot",code="it"):
    site = wikipedia.getSite(code)
    page = wikipedia.Page(site, nome_pagina)
    
    
    if aggiungi:
        contenuto = page.get()
        try:
            page.put(newtext=contenuto+u"\n\n"+testo,comment=commento,minorEdit=False)
            
        except wikipedia.LockedPage:
            return "Pagina bloccata"
    else:
        try:
            page.put(newtext=testo,comment=commento,minorEdit=False)
        except wikipedia.LockedPage:
            return "Pagina bloccata"
    wikipedia.stopme()
    return "Fatto"


def list_in_cat(category_name,site="base"):
    site = wikipedia.getSite()
    cat = catlib.Category(site,'Category:'+category_name)
    gen = pagegenerators.CategorizedPageGenerator(cat)
    page_list=[]
    for page in gen:
    #Do something with the page object, for example:
        page_list.append(page.title())
    return page_list
# Routine generiche
# dumps a variable

## General string management routines for RegEx ignorants :-(

# finds a substring beginning with idi and ending with idf; returns it
# with (dc=1) or without (default dc=0) idi and idf; used for xml managing too

def find_stringa(stringa,idi,idf,dc=0,side="left"):
    if side=="right":
        idip=stringa.rfind(idi)
    else:
        idip=stringa.find(idi)
    idfp=stringa.find(idf,idip+len(idi))+len(idf)
    if idip>-1 and idfp>0:
        if dc==0:
            vvalore=stringa[idip+len(idi):idfp-len(idf)]
        else:
            vvalore=stringa[idip:idfp]
    else:
        vvalore=""
    return vvalore

# variant; as find_stringa, but searches into stringa from offset (default 0);
# returns substring without and with delimiters, the absolute offset of the
# second delimiter, the indices of the substring (null strings if not found)

def find_next(stringa,idi,idf,offset=0):
    idip=stringa.find(idi,offset)
    idfp=stringa.find(idf,idip+len(idi))+len(idf)
    if idip>-1 and idfp>0:
        
        stringa_i=stringa[idip+len(idi):idfp-len(idf)]
        stringa_t=stringa[idip:idfp]
##        if stampa:
##            print stringa_t,
        offset=idfp-len(idf)
    else:
        stringa_i=''
        stringa_t=''
    return stringa_i,stringa_t,offset,idip,idfp

# appoggiandosi a find_next, produce una lista di tutte le istanze della
# sottostringa idi...idf, contenente per ciascun valore i dati:
# stringa_i,stringa_t,offset,idip,idfp

def find_all(stringa,idi,idf):
    lista=[]
    offset=0
    while True:
        r=find_next(stringa,idi,idf,offset)
        if r[0]!="":
            lista.append(r)
            offset=r[2]
        else:
            return lista

def find_split(stringa,idi,idf):
   ''' seziona una stringa utilizzando una sottoscringa come elemento di separazione

   la sottostringa è identificata da idi,idf; il risultato è una lista di stringhe
   analoga a quella prodotta da splitter'''
   
   result=[]
   rp=[]
   tagged=find_all(stringa,idi,idf)
##   for i in range(len(tagged)):
##      tagged[i]=[tagged[i][1],tagged[i][3],tagged[i][4]]
   #print tagged
   if len(tagged)==0: # caso nessun tagged
      result.append(stringa)
      return result
   if tagged[0][3]!=0: # caso tagged non all'inizio di pagina
      rp.append(stringa[0:tagged[0][3]])
   for i in range(len(tagged)):
      rp.append(tagged[i][1])
      if i==len(tagged)-1: # se è stato trattato l'ultimo elemento tagged
         rp.append(stringa[tagged[i][4]:]) # aggiungi il resto di stringa
         return rp
      rp.append(stringa[tagged[i][4]:tagged[i+1][3]])
   return rp

    

# restituisce la stringa idi...ifd "a cavallo" di offset
# senza (dc=0) o con (dc!=0) i delimitatori idi...idf
        
def find_r(stringa,idi,idf,offset,dc=1):
    idip=stringa.rfind(idi,0,offset)
    idfp=stringa.find(idf,idip+len(idi))+len(idf)
    if idip>-1 and idfp>0:
        if dc==0:
            vvalore=stringa[idip+len(idi):idfp-len(idf)]
        else:
            vvalore=stringa[idip:idfp]
    else:
        vvalore=""
    return vvalore
    
        
# replaces the first substring idi...idf into string with new; returns
# a tuple with whole replaced string and substring that has been removed/replaced

def el_st(stringa,idi,idf,new=""):
    idip=stringa.find(idi)
    idfp=stringa.find(idf,idip)+len(idf)
    if idip>-1 and idfp>0:
        vvalore=stringa[idip:idfp]
        valore=stringa.replace(vvalore,new,1)
    else:
        vvalore=""
        valore=stringa
    return valore, vvalore

# returns a list of all substrings (beginning with idi and ending with idf)
# of a string; ; used for xml data managing too

def produci_lista(testo,idi,idf,dc=0):
    t=testo[:]
    lista=[]
    while not find_stringa(t,idi,idf)=="":
        el=find_stringa(t,idi,idf,1)
        t=t.replace(el,"")
        #print el
        if dc==0:
            el=find_stringa(el,idi,idf,0)
        #print el
        #print
        lista.append(el)
    return lista

def produci_lista1(testo,idi,idf,dc=0):
    t=testo[:]
    lista=[]
    while not find_stringa(t,idi,idf)=="":
        el=find_stringa(t,idi,idf,1)
        t=t.replace(el,"",1)
        #print el
        if dc==0:
            el=find_stringa(el,idi,idf,0)
        #print el
        #print
        lista.append(el)
    return lista

def carica_pcl(nome_file, folder="dati/"):
    nome_file=folder+nome_file+".pcl"
    f=open(nome_file)
    contenuto=pickle.load(f)
    f.close()
    return contenuto
def salva_pcl(variabile,nome_file="dato",folder="dati/"):
    nome_file=folder+nome_file+".pcl"
    f=open(nome_file,"w")
    pickle.dump(variabile, f)
    f.close()
    return "Variabile salvata nel file "+nome_file
def imagepage(titolo): #restituisce un oggetto ImagePage da Commons
   #famiglia=wikipedia.Family("commons")
   commons=wikipedia.getSite("commons",wikipedia.Family("commons"))
   paginaImmagine=wikipedia.ImagePage(commons,titolo)
   return paginaImmagine
   
      
def leggi_pagina_html(nome_pagina=u"Utente:Alex brollo"):
    site = wikipedia.getSite()
    page = wikipedia.Page(site, nome_pagina)
    try:
        text = site.getUrl(nome_pagina) # Taking the text of the page
    except wikipedia.NoPage: # First except, prevent empty pages
        text = ''
    except wikipedia.IsRedirectPage: # second except, prevent redirect
        text = "#REDIRECT"
        # output(u'%s is a redirect!' % pagename)
        
    except wikipedia.Error: # third exception, take the problem and print
        output(u"Some error, skipping..")

    wikipedia.stopme()
    return text

def aggiornaSalIndice(nomeIndice,testoIndice): # riceve il nome di una pagina Indice e aggiorna il parametro SAL
    sal=qualitaIndice(nomeIndice)
    #testoIndice=leggi_pagina(nomeIndice)
    salPerc="25%"
    if sal==2:
        salPerc="50%"
    elif sal==3:
        salPerc="75%"
    elif sal==4:
        salPerc="100%"
    elif sal==0:
        print "Bug in azione - procedura annullata"
        return testoIndice
    qualIndice=find_stringa(testoIndice,u"|Qualità=","\n",1)
    
    qualIndiceNew=u"|Qualità="+salPerc+"\n"
    print "sal=",sal,salPerc, qualIndice,qualIndiceNew
    testoIndiceNew=testoIndice.replace(qualIndice,qualIndiceNew)
    tlQualita=find_stringa(testoIndiceNew,u"{{Qualità|","}}",1)
    if tlQualita!="":
        testoIndiceNew=testoIndiceNew.replace(tlQualita,"")
    return testoIndiceNew

        
    
    
    
        
    
    

def creaPagina(nome):
   site = wikipedia.getSite()
   page = wikipedia.Page(site, nome)
   return Autore(page)

def qualitaIndice(nomeIndice="Indice:Africa orrenda.djvu"):
    listaQi=elencoPagineIndice(nomeIndice,True,True)
    print "Numero elementi:",len(listaQi)
    maxq=0
    testoLista="/n".join(listaQi)
    
    if 'class="new"' in testoLista:
        maxq=1
        
    elif 'class="quality1"' in testoLista:
        maxq=1
        
    elif 'class="quality2"' in testoLista:
        maxq=2
        
    elif 'class="quality3"' in testoLista:
        maxq=3
        
    elif 'class="quality4"' in testoLista:
        maxq=4

    return maxq

        
        
        


def elencoPagineIndice1(indice,tutte=False):
    #elenco_pagine=[]
    #inizializzazione oggetto Page su pagina indice
    site=wikipedia.getSite()
    page=wikipedia.Page(site,indice)

    # calcolo nome x url
    nomeindice="/wiki/"+page.urlname()
    
    #lettura HTML originario (prima delle alterazioni js)
    testo=leggi_pagina_html(nomeindice)
    
    #ricerca di tutti i tag <a href..>...</a> e salvataggio su file
    pagine=produci_lista(testo,'<a href="',"</a>",1)
    titoli=[]
    for i in pagine:
         if tutte:
           if ('title="Pagina:' in i) and ("class=" in i):
               titolo=find_stringa(i,'title="','"').replace(" (tuttora non scritto)","")
               #qp=find_stringa(i,'class="','"')
               if not titolo in titoli:
                   #elenco_pagine.append([titolo,qp])
                   titoli.append(titolo)
         else:
            if ('title="Pagina:' in i) and ("class=" in i) and (not " (tuttora non scritto)" in i):
               titolo=find_stringa(i,'title="','"')
               if not titolo in titoli:
                  titoli.append(titolo)
            

    return titoli
   
def azzeraDumpNuovePagine(ns="Pagina"):
   if ns in ["Autore","Principale","Indice","Pagina"]:
      salva_pcl([],"nuove"+ns)
   else:
      print ns,' : parametro errato (usa uno fra ["Autore","Principale","Indice","Pagina"]'
   return

def aggiornaAutore(pagina,commento="Aggiornamento autore via Alebot"):
   wikipedia.setAction=commento
   pagina.page.put(pagina.testo,comment=commento)
   wikipedia.stopme()
   return "Fatto"
   

"""File downloading from the web.
"""

   
def download(url):
	"""Copy the contents of a file from a given URL
	to a local file.
	"""
	import urllib
	webFile = urllib.urlopen(url)
	localFile = open("immagini/"+url.split('/')[-1], 'w')
	localFile.write(webFile.read())
	webFile.close()
	localFile.close()

if __name__ == '__main__':
	import sys
	if len(sys.argv) == 2:
		try:
			download(sys.argv[1])
		except IOError:
			print 'Filename not found.'
	else:
		import os
		print 'usage: %s http://server.com/path/to/filename' % os.path.basename(sys.argv[0])

def go(secondi=1800, cicli=20):
   ''' ciclo timer che chiama leggi_richieste ogni n secondi per m volte

   Utilizzato nel bot interattivo'''
   rcSession()
   for i in range(cicli):
      t=Timer(secondi, rcSession)
      t.start()
      t.cancel()
   return

def estraiSectionAc():
   ac=leggi_pagina("Template:Ac/Dati")
   l1=produci_lista(ac, "<section begin","/>",1)
   l2={}  
   for i in l1:
      autoreBreve=i.replace("<section begin=","").replace(" />","")
      autoreLungo=find_stringa(ac,i,i.replace("begin=","end="))
      l2[autoreBreve]=autoreLungo
   return l2

def normalizzaAc(ac): #riceve un tl Ac
   ac=ac.replace("{{a","{{A")
   ac=ac.replace("{{AutoreCitato|","{{Ac|")
   acpar=find_stringa(ac,"{{Ac|","}}").split("|")
   print "acpar:",acpar
   if len(acpar)==1:
      if leggi_pagina("Autore:"+acpar[0])>"":
         acnorm=ac
      elif acpar[0] in autoreCitato:
         acnorm=ac.replace("{{Ac|","{{Ac|"+autoreCitato[acpar[0]]+"|")
      else:
         acnorm=ac
   else:
      acnorm=ac
   return acnorm

def normalizzaAcPagina(testo):
   if "{{autorecitato|" in testo.lower() or "{{ac|" in testo.lower():
      testo=testo.replace("{{autoreCitato|","{{AutoreCitato|")
      testo=testo.replace("{{ac|","{{Ac|")
      testo=testo.replace("{{AutoreCitato|","{{Ac|")
      listaAc=produci_lista(testo,"{{Ac|","}}",1)
      for ac in listaAc:
         acn=normalizzaAc(ac)
         testo=testo.replace(ac,acn)
   return testo

##def move(self, newtitle, reason=None, movetalkpage=True, movesubpages=False, sysop=False,
##             throttle=True, deleteAndMove=False, safe=True, fixredirects=True, leaveredirect=True):
def rinomina(oldtitle,newtitle, leaveRedirect=False, movesubpages=False, movetalkpage=True,site="it"):
   ''' note

   leaveRedirect=False: non lascia dietro redirect (lo sopprime immediatamente)
   safe, deleteAndMove, fixredirects: ignorare (servono a vecchie routine)
   movetalkpage: viene ignorato se si tratta di una pagina di discussione'''
   if leaveRedirect:
      reason="Spostamento pagina via bot con creazione di redirect (default)"
   else:
      reason="Spostamento pagina via bot senza creazione di redirect"
   pagina=wikipedia.Page(site,oldtitle)
   result=pagina.move(newtitle,leaveRedirect=leaveRedirect,safe=safe,
                      movesubpages=movesubpages,movetalkpage=movetalkpage, reason=reason)
   return
   
   
   
   
# Parte attiva del programma

autoreCitato=estraiSectionAc()
vai=raw_input("Avvio il bot?")
if vai.lower() in ["s","si"]:
    secondi= raw_input("Secondi fra i cicli:")
    if secondi=='':
       secondi=1800
    else:
       secondi=eval(secondi)
    
    numeroCicli=raw_input("Numero cicli:")
    if numeroCicli=='':
       numeroCicli=20
    else:
       numeroCicli=eval(numeroCicli)
       
       go(secondi,numeroCicli)