用python读取文本文件并形成字典

2024-06-16 11:21:59 发布

您现在位置:Python中文网/ 问答频道 /正文

我有档案数据.txt,下面的python代码读取文本并形成字典。你知道吗

文件:数据.txt你知道吗

10/20   vinay   
05/31   hunachyal
11/23   mine

bday_list = {}


infile = open("data.txt")
for line in infile:
    List_array = [w.strip() for w in line.split("\t")]
    bday_list[List_array[0]] = List_array[1]
#    print line

print bday_list


 Op: {'11/23': 'mine', '10/20': 'vinay', '05/31': 'hunachyal'}

类似地,如何以OP中所示的格式获取以下文件的dictionary

文件

  10/20 Name    vinay   phone   +91094xxx   
  05/31 Name    hunachyal   phone +91jndjxx
  11/23 Name    mine    phone +92jdddxxx

  OP:

  {'11/23': {'Phone': '+91kexxx', 'Name': 'mine'}, '10/20': {'Phone': '+919xxxx', 'Name': 'vinay'}, '05/31': {'Phone': '+9194xxxx', 'Name': 'hunachyal'}}

或者在python中是否有任何方法可以形成数据库,在这里我可以轻松地获取数据。你知道吗


Tags: 文件数据nametxtlinephonearrayinfile
3条回答

你也可以试试这个

bday_list = {}
with open('data.txt', 'r') as R:
    for line in R:
        l = line.strip().split()  # split the line to list
        bday_list[l[0]] = {k:v for k,v in zip(l[1::2], l[2::2])}

PS,
如果您使用infile = open(...)而不是with open() as infile:来处理文件句柄,那么您应该记住在之后close处理文件句柄。你知道吗

这应该适合您:

f = open('filename.txt').readlines()

f = [i.strip('\n').split() for i in f]

new_dict = {i[0]:{i[b]:i[b+1] for b in range(1, len(i), 2) if b+1 < len(i)} for i in f}

print new_dict

请尝试以下方法:

>>> data = """10/20 Name    vinay   phone   +91094xxx   
...   05/31 Name    hunachyal   phone +91jndjxx
...   11/23 Name    mine    phone +92jdddxxx
... """
>>> 
>>> result = {}
>>> 
>>> for line in data.splitlines():
...     dataList = line.split()
...     result[dataList[0]] = {dataList[1]: dataList[2], dataList[3]: dataList[4]}
... 
>>> result
{'11/23': {'Name': 'mine', 'phone': '+92jdddxxx'}, '10/20': {'Name': 'vinay', 'phone': '+91094xxx'}, '05/31': {'Name': 'hunachyal', 'phone': '+91jndjxx'}}

相关问题 更多 >