所以我从我用来学习Python的书中复制并粘贴了一个演示程序:
#!/usr/bin/env python
import csv
total = 0
priciest = ('',0,0,0)
r = csv.reader(open('purchases.csv'))
for row in r:
cost = float(row[1]) * float(row[2])
total += cost
if cost == priciest[3]:
priciest = row + [cost]
print("You spent", total)
print("Your priciest purchase was", priciest[1], priciest[0], "at a total cost of", priciest[3])
我得到了错误:
Traceback (most recent call last):
File "purchases.py", line 2, in <module>
import csv
File "/Users/Solomon/Desktop/Python/csv.py", line 5, in <module>
r = csv.read(open('purchases.csv'))
AttributeError: 'module' object has no attribute 'read'
为什么会这样?我如何解决它? 更新: 修正所有错误 现在我得到了:
Traceback (most recent call last):
File "purchases.py", line 6, in <module>
for row in r:
_csv.Error: line contains NULL byte
CSV.py发生了什么: 我有一个名为csv.py的相同代码的文件,保存在同一目录中。我认为它被命名为csv .py的事实是搞砸了,所以我开始了一个名为purchases.py的新文件,但是忘了删除csv
答案 0 :(得分:76)
请勿将文件命名为csv.py
当您这样做时,Python会在您的文件中查找csv
代码,而不是标准库csv
模块。
答案 1 :(得分:3)
错误追溯中的代码之间存在差异:
r = csv.read(open('purchases.csv'))
您发布的代码:
r = csv.reader(open('purchases.csv'))
你在使用哪个?
无论如何,修复第2行中的缩进错误:
#!/usr/bin/env python
import csv
total = 0
使用上下文处理程序创建csv reader对象,以免文件句柄处于打开状态:
with open('purchases.csv') as f:
r = csv.reader(f)