遇见的python问题--如何将文件里的内容转换成字典类型


文件内容如下:

liuyang,123456

liyun,123456

zhangsna,12345lkj

 

#方法一:从文件中读取数据,一行读取一个列表,读取出一个嵌套的列表,再转换成字典

with open('users', 'r', encoding='utf-8')as f:

    dic = []

    for line in f.readlines():

        line = line.strip('\n')

        b = line.split(',')

        dic.append(b)

dic = dict(dic)

print(dic)

#方法二:从文件中读取数据,一行读取一个列表,读取出一个嵌套的列表,再转换成字典

with open('users', 'r', encoding='utf-8')as f:

    dic = []

    for line in f.readlines():

        line = line.strip('\n')

        b = line.split(',')

        dic.append(b)

new_dict = {}

for i in dic:

    new_dict[i[0]] = i[1]

print(new_dict)

nums = new_dict.keys()[0]

print(nums)

print(nums[3])

#方法三:从文件中读取数据,一行读取一个列表,读取出一个嵌套的列表,再转换成字典

with open('users', 'r', encoding='utf-8')as f:

    res = dict(line.strip().split(',') for line in f if line)

    print(res)

 

执行过程中报错:dictionary update sequence element #8 has length 1; 2 is required

找了半天问题出现的原因,结果竟因为文件内的最后一行是空行导致的。好吧,我就不说什么了,建议查找问题的时候打印出每一步的操作结果,就发现问题了。


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM