re.search con \ s o '\ n' non sta trovando la multilinea che sto cercando di cercare.re.search Linee multiple Python
Porzione di Fonte:
Date/Time:
2013-08-27 17:05:36
----- BEGIN SEARCH -----
GENERAL DATA:
NAME: AB12
SECTOR:
999,999
CONTROLLED BY: Player
ALLIANCE: Aliance
ONLINE: 1 seconds ago
SIZE: Large
HOMEWORLD: NO
APPROVAL RATING: 100%
PRODUCTION RATE: 100%
RESOURCE DATA:
POWER: 0/0
BUILDINGS: 0/20
ORE: 80,000/80,000
CRYSTAL: 80,000/80,000
POPULATION: 40,000/40,000
BUILDING DATA:
N/A
UNIT DATA:
WYVERN(S): 100
----- END SEARCH -----
Guardando in Notepad ++ vedo "DATI STRUTTURALI: (LF)"
pieno Codice
lines = open('scan.txt','r').readlines()
for a in lines:
if re.search(r"\A\d", a):
digits = a
if re.search(r"2013", digits):
date.append(digits[:19])
count +=1
elif re.search(r",", digits):
clean = digits.rstrip()
sector = clean.split(',')
x.append(sector[0])
y.append(sector[1])
elif re.search(r"CONTROLLED BY:", a):
player.append(a[15:].rstrip())
elif re.search(r"ALLIANCE:", a):
alliance.append(a[10:].rstrip())
elif re.search(r"SIZE:", a):
size.append(a[6:].rstrip())
elif re.findall('BUILDING DATA:\sN/A', a, re.M):
def_grid = ''
print "Didn't find it"
defense.append(def_grid)
defense_count +=1
elif re.search(r"DEFENSE GRID", a):
def_grid = a[16:].rstrip()
print "defense found"
defense_count +=1
Ma io non sto avendo nulla restituito .
ho bisogno di mettere un distanziatore vuoto quando "Defense Grid" non esiste dopo "DATI EDIFICIO:"
So che mi manca qualcosa e ho provato leggendo su re.search ma Non sono in grado di trovare esempi approfonditi che spieghino come funziona la multilinea.
A [sscce] (http://sscce.org/) sarebbe bello. È difficile capire quale sia esattamente il problema. –
Penso che ti sia dimenticato di "import re" e questo esempio non funziona immediatamente. la data non è stata definita ... –