Sto cercando di scrivere una lista di una lista in un nuovo file, ma sto ottenendo questo errore:TypeError: atteso un oggetto buffer di caratteri
Traceback (most recent call last): File "", line 1, in dowork() File "C:\Python27\work\accounting\formatting quickbooks file\sdf.py", line 11, in dowork WriteFile() File "C:\Python27\work\accounting\formatting quickbooks file\sdf.py", line 71, in WriteFile f.write(thefile) TypeError: expected a character buffer object
Come faccio a scrivere un elenco di un elenco di un file?
questo è come mi sto scrivendo:
def WriteFile():
global thefile
f = open("output"+'.csv','w')
f.seek(0)
f.write(thefile)
f.close()
e qui è la sorgente completo in caso di necessità:
import csv
thefile = []
output = []
def dowork():
sourceFile='e.csv'
thefile=ReadFile(sourceFile)
CleanFile(sourceFile)
ProcessFile()
WriteFile()
def ReadFile(filename):
return list(csv.reader(open(filename, 'rb'), delimiter=',', quotechar='"'))[1:]
def CleanFile(sourceFile):
global thefile
thefiletmp=[]
for i, line in enumerate(thefile):
if line[2]=='':
del thefile[i]
else:
thefiletmp.append(line[4:])
thefile=thefiletmp
def ProcessFile():
global thefile
iCompany=1
iNum=0
iDate=2
iAging=3
iBalance=4
COMPANIES=GetDistinctValues(1)
mytemparray=[]
mytempfile=[]
for company in COMPANIES:
for line in thefile:
if line[iCompany]==company:
mytemparray.append(line[iCompany])
mytemparray.append(line[iNum])
mytemparray.append(line[iDate])
if line[2] in range(0,31):
mytemparray.append(line[iBalance])
mytemparray.append('0')
mytemparray.append('0')
mytemparray.append('0')
if line[2] in range(31,61):
mytemparray.append('0')
mytemparray.append(line[iBalance])
mytemparray.append('0')
mytemparray.append('0')
if line[2] in range(61,91):
mytemparray.append('0')
mytemparray.append('0')
mytemparray.append(line[iBalance])
mytemparray.append('0')
if line[2] >90:
mytemparray.append('0')
mytemparray.append('0')
mytemparray.append('0')
mytemparray.append(line[iBalance])
mytempfile.append(mytemparray)
mytemparray=[]
thefile=mytempfile
def WriteFile():
global thefile
f = open("output"+'.csv','w')
f.seek(0)
f.write(thefile)
f.close()
def GetDistinctValues(theColumn):
return sorted(list(set(line[theColumn] for line in thefile)))
Dovresti davvero sostituire la variabile globale con una variabile che passi a ciascuna funzione e chiudere i file quando hai finito con loro. E ora che possiamo vedere l'intero codice, ti consiglio caldamente di riorganizzarlo in modo da avere una funzione 'ProcessLine' (puoi semplicemente invertire i cicli' line' e 'company'), e solo filtrare riga per riga, quindi non è necessario un elenco e non è necessario rimuovere elementi dall'elenco sul posto e così via. Il tutto sarebbe molto più semplice in questo modo. – abarnert
possibile duplicato di [TypeError: previsto un oggetto buffer di caratteri - durante il tentativo di salvare un intero in file di testo] (http: // stackoverflow.it/questions/9786941/typeerror-expected-a-character-buffer-object-while-trying-to-save-integer-to) –