Mappa posizione della stringa di numero di riga in uscita regex
Domanda
Sto lavorando su un programma di utilità "grep-like" in Python per la ricerca di file di codice sorgente di Oracle. standard di codifica sono cambiati nel corso del tempo, in modo da cercare di trovare qualcosa di simile a "tutto cancella dalla tabella a.foo" potrebbe estendersi su più righe, o meno, a seconda dell'età di quel pezzo di codice:
s = """-- multiline DDL statement
DELETE
a.foo f
WHERE
f.bar = 'XYZ';
DELETE a.foo f
WHERE f.bar = 'ABC';
DELETE a.foo WHERE bar = 'PDQ';
"""
import re
p = re.compile( r'\bDELETE\b.+?a\.foo', re.MULTILINE | re.DOTALL )
for m in re.finditer( p, s ):
print s[ m.start() : m.end() ]
Questa Uscite:
DELETE
a.foo
DELETE a.foo
DELETE a.foo
Quello che voglio:
[2] DELETE
[3] a.foo
[7] DELETE a.foo
[10] DELETE a.foo
C'è un / modo rapido semplice / builtin per mappare gli indici di stringa alla linea numeri?
Soluzione
lineno = s.count("\n",0,m.start())+1
Autorizzato sotto: CC-BY-SA insieme a attribuzione
Non affiliato a StackOverflow