为什么我得到 ValueError:dict 包含字段名称中不在字段名称中的字段,尝试将 Python 字典写入 csv



我收到此错误

ValueError: dict contains fields not in fieldnames: 'bobama', 'mfisc', 'nhay', 'bgates', 'jdoe', 'sburry', 'mcuban'

使用以下代码:

class Authentication:
def __init__(self):
# instantiate an instance variable
self.user_dict = {}
def register_user(self, uname, passwd):
if uname in self.user_dict:
print("Username exists! Try a new one.")
return False
else:
self.user_dict[uname] = passwd
print("Registration successful" )
return True    
def data_entry(auth):
# registering 3 users
auth.register_user('jdoe', '$234^%$') # Jane Doe
auth.register_user('sburry', '456@#&^') # Sam Burry
auth.register_user('mfisc', '%6&#$@#') # Mike Fischer
auth.register_user('nhay', 'ildfu45') # Nicky Hailey
auth.register_user('bobama', 'klj43509jafd') # Barack Obama
auth.register_user('bgates', '^&%kjsfd934@#$') # Bill Gates 
auth.register_user('mcuban', '9&4rl#nsf') # Mark Cuban
# Main program
auth = Authentication()
data_entry(auth)
dictt = auth.user_dict
import csv
class AuthenticationIOcsv(Authentication):
def write_info(self):
fname='userinfo.csv'        
with open(fname,'w') as op_file:
field_names = ['Username', 'Password']
op_writer = csv.DictWriter(op_file, fieldnames=field_names)
op_writer.writeheader()
op_writer.writerow(dictt)        
# Main Program
auth = AuthenticationIOcsv()
data_entry(auth)
# writing to file
auth.write_info()

该项目的目的是使用继承和子类创建一个csv文件,其中包含带有标题"用户名"和"密码"的列,然后分别包含这些列中的字典键和值。我已经尝试了其他一些解决方案,将字典编写为csv,我可以发布这些解决方案,但导致只有标题的空白csv文件或其他类型的错误。例如:

op_writer = csv.DictWriter(op_file, fieldnames=field_names)
op_writer.writeheader()
for key, value in dictt.items():
op_writer.writerow([key,value])

我收到此错误:

AttributeError: 'list' object has no attribute 'keys'

我对 Python 相当陌生,所以任何指导将不胜感激!我显然正在努力了解如何以这种方式访问字典项目以导出到 excel。提前谢谢你。

>这是一个DictWriter,只接收dict data。 您可以使用这种方式写入数据:

op_writer = csv.DictWriter(op_file, fieldnames=field_names)
op_writer.writeheader()
for username, pwd in dictt.items():
op_writer.writerow({"Username": username, "Password": pwd})

最新更新