2013-05-06 13 views
22

Il seguente codice restituisce un'uscita leggibile.Rimuovi caratteri prima e incluso _ in python 2.7

def add_line_remove_special(ta_from,endstatus,*args,**kwargs): 
    try: 
     ta_to = ta_from.copyta(status=endstatus) 
     infile = botslib.opendata(ta_from.filename,'r') 
     tofile = botslib.opendata(str(ta_to.idta),'wb') 
     start = infile.readline() 
     import textwrap 
     lines= "\r\n".join(textwrap.wrap(start, 640)) 
     tofile.write(lines) 
     infile.close() 
     tofile.close() 

Questa è l'uscita, ora vorrei per rimuovere tutti i caratteri fino e compreso il _

Ichg_UNBUNOA3         14    2090100000015      14    1304221445000001 
MSG_BGM380           610809        9 NA 
MSG_DTM13720130422       102 
Grp1_RFFON test EDI 
Grp2_NADBY 2090100000015       9 
Grp2_NADIV 2090100000015       9 
Grp2_NADDP 2090100000015       9 
Grp7_CUX2 EUR4 
Grp8_PAT22                        5 3 D 30 
Grp25_LIN1  02090100000022      EN 
Grp25_QTY47    5 
Grp25_QTY12    5 
Grp26_MOA203    15.00 
Grp28_PRIINV  3000.00   1000PCE 
Grp33_TAX7 VAT                     21.00        S 
Grp25_LIN2  02090100000039      EN 
Grp25_QTY47    10 
Grp25_QTY12    10 
Grp26_MOA203   350.00 
Grp28_PRIINV  35000.00   1000PCE 
Grp33_TAX7 VAT                     21.00        S 

Come posso fare questo?

risposta

47

Per ottenere tutto il testo su una riga dopo un carattere di sottolineatura, divisi al primo _ carattere e prendere l'ultimo elemento del risultato:

line.split('_', 1)[-1] 

Ciò funzionerà anche per le linee che fare non hanno un carattere di sottolineatura sulla linea.

Demo:

>>> 'Grp25_QTY47    5'.split('_', 1)[-1] 
'QTY47    5' 
>>> 'No underscore'.split('_', 1)[-1] 
'No underscore' 

Traducendo questo per il tuo codice:

import textwrap 

ta_to = ta_from.copyta(status=endstatus) 
with botslib.opendata(ta_from.filename,'r') as infile: 
    with botslib.opendata(str(ta_to.idta),'wb') as tofile: 
     for line in textwrap.wrap(next(infile), 640): 
      line = line.split('_', 1)[-1] 
      tofile.write(line + '\r\n') 
+0

ho bisogno di aggiungere per la linea in linee: line.split ('_', 1) [- 1 ] tra le righe = .... e tofile.write ... – user2343368

+0

Sì, è necessario eseguire questa operazione per ciascuna riga. –

+0

'infile = botslib.opendata (ta_from.filename, 'r') tofile = botslib.opendata (str (ta_to.idta), 'wb') Start = infile.readline() importazione textwrap linee = "\ r \ n ".join (textwrap.wrap (start, 640)) per righe: line.split ('_', 1) [- 1] tofile.write (righe) infile.close() tofile.close() ' restituisce solo l'ultimo carattere del file = S – user2343368