回答此问题可获得 20 贡献值,回答如果被采纳可获得 50 分。
<p>我无法从txt文件到字典列表中获得正确的值。
我调用文本文件的原始输出,逐行读取,删除空白并解析到字典中。你知道吗</p>
<p>请在下面找到包含产品id和产品名称的txt文件。
请注意,文件源中的一些数据内容是颠倒的..我的意思是产品id排在产品名称之前(不按顺序排列)…请参考下面的示例数据</p>
<pre><code>Product id: sq112
Prodname: ment-bar1
Product id: sq001
Prodname: jumw-cd12
Product id: mcc-hg921
Prodname: emq-vx02
Product id: mmc112
Prodname: ment-bar2
Product id: cx022
Prodname: mxx-21ed
Product id: vcb113
Prodname: emq-vx05
Prodname: trc-vc01
Product id: emx-21ee
</code></pre>
<p>这是用于获取id和名称的脚本</p>
<pre><code>file = open("prd1.txt")
data = file.readlines()
dict = {"ProdList":[]}
temp_dict ={}
for line in data:
line = line.replace('\n', '').strip()
line = line.split(':')
line = list(filter(None,line))
temp_dict["ID"] = line[0]
temp_dict["Name"] = line[1]
dict["ProdList"].append(temp_dict)
temp_dict = {}
print(dict)
</code></pre>
<p>dict输出如下所示</p>
<pre><code>{'ProdList': [{'ID': 'Product id', 'Name': ' sq112'}, {'ID': 'Prodname',
'Name': ' ment-bar1'}, {'ID': 'Product id', 'Name': ' sq001'}, {'ID':
'Prodname', 'Name': ' jumw-cd12'}, {'ID': 'Product id', 'Name': ' mcc-
hg921'}, {'ID': 'Prodname', 'Name': ' emq-vx02'}, {'ID': 'Product id',
'Name': ' mmc112'}, {'ID': 'Prodname', 'Name': ' ment-bar2'}, {'ID':
'Product id', 'Name': ' cx022'}, {'ID': 'Prodname', 'Name': ' mxx-21ed'},
{'ID': 'Product id', 'Name': ' vcb113'}, {'ID': 'Prodname', 'Name': ' emq-
vx05'}]}
</code></pre>
<p>预期产出如下</p>
<pre><code>{'ProdList':[{'ID':'sq112','Name':' ment-bar1'},{'ID':'sq001','Name':'
jumw-cd12'},{'ID':'mcc-hg921','Name':' emq-vx02'}]}
</code></pre>
<p>我按照下面的建议试过了</p>
<pre><code>for i in range(0,len(data),2):
line = data[i].split(':')
nxt_line = data[i+1].split(':')
if 'id' in data[0]:
dict['ProdList'].append({'ID':line[1], 'Name': nxt_line[1]})
else:
dict['ProdList'].append({'ID':nxt_line[1], 'Name': line[1]})
</code></pre>
<p>我得到下面的输出</p>
<pre><code>{'ProdList':[{'ID':' sq112\n','Name':' ment-bar1\n'},{'ID':'
sq001\n','Name':' jumw-cd12\n'},{'ID':' mcc-hg921\n','Name':' emq-vx02\n'},
{'ID':' mmc112\n','Name':' ment-bar2\n'},{'ID':' cx022\n','Name':' mxx-
21ed\n'},{'ID':' vcb113\n','Name':' emq-vx05\n'},{'ID':' trc-
vc01\n','Name':' emx-21ee \n'}]}
</code></pre>
<p>最后一个身份证和产品名称颠倒过来。。。它应该是ID:emx-21ee和名称:trc-vc01</p>