[Обратите внимание, что это вопрос, отличный от уже отвеченного Как заменить столбец с помощью встроенного в Python модуля записи .csv? ]
Мне нужно найти и заменить (специфично для одного столбца URL) в огромном файле .csv Excel. Поскольку я только начинаю пытаться учить себя языку сценариев, я решил, что попытаюсь реализовать решение на python.
У меня проблемы с попыткой обратной записи в файл .csv после внесения изменений в содержимое записи. Я прочитал официальную документацию модуля csv о том, как использовать писатель, но нет примера, который бы охватывал этот случай. В частности, я пытаюсь получить операции чтения, замены и записи, выполненные за один цикл. Однако нельзя использовать одну и ту же ссылку 'row' как в аргументе цикла for, так и в качестве параметра для writer.writerow (). Итак, после внесения изменений в цикл for, как мне записать обратно в файл?
edit: Я реализовал предложения С. Лотта и Джимми, все тот же результат
edit # 2: Я добавил "rb" и "wb" в функции open (), согласно предложению С. Лотта
import csv
#filename = 'C:/Documents and Settings/username/My Documents/PALTemplateData.xls'
csvfile = open("PALTemplateData.csv","rb")
csvout = open("PALTemplateDataOUT.csv","wb")
reader = csv.reader(csvfile)
writer = csv.writer(csvout)
changed = 0;
for row in reader:
row[-1] = row[-1].replace('/?', '?')
writer.writerow(row) #this is the line that's causing issues
changed=changed+1
print('Total URLs changed:', changed)
edit: Для справки: new full traceback от интерпретатора:
Traceback (most recent call last):
File "C:\Documents and Settings\g41092\My Documents\palScript.py", line 13, in <module>
for row in reader:
_csv.Error: iterator should return strings, not bytes (did you open the file in text mode?)