我想将列的内部提取为多个列。这是导入到dataframe后的原始数据
data = {'ID': ['A0001', 'A0002', 'A0003', 'A0004', 'A0005'],
'Name': ['John', 'Micheal', 'Angle', 'Jim', 'Rome'],
'Details': ['Type:\nHouse\nVector:\nTriangle\n\nMission:\nCompleted,lv5\n\nNote user:\n#', 'Type:\n#\nVector:\n\n\nMission:\nFailed\nNote user:\n#', 'Type:\nCar\nVector:\nSquare\nMission:\nCompleted\nNote user:\n', 'Type:\n#\nVector:\n#\nMission:\nCompleted without award\n\nNote user:\nNo end', 'Type:\n#\nVector:\n#\nMission:\n\n\nNote user:\nThere are many mistake.\nI cant choose.\nI cant buy.']
}
df = pd.DataFrame (data, columns=['ID', 'Name', 'Details'])
df
ID Name Details
A0001 John Type:\nHouse\nVector:\nTriangle\n\nMission:\nCompleted,lv5\n\nNote user:\n#
A0002 Micheal Type:\n#\nVector:\n\n\nMission:\nFailed\nNote user:\n#
A0003 Angle Type:\nCar\nVector:\nSquare\nMission:\nCompleted\nNote user:\n
A0004 Jim Type:\n#\nVector:\n#\nMission:\nCompleted without award\n\nNote user:\nNo end
A0005 Rome Type:\n#\nVector:\n#\nMission:\n\n\nNote user:\nThere are many mistake.\nI cant choose.\nI cant buy.
我想提取“详细信息”列中的值。但我不知道该怎么做
我预期的数据如下所示
data = {'ID': ['A0001', 'A0002', 'A0003', 'A0004', 'A0005'],
'Name': ['John', 'Micheal', 'Angle', 'Jim', 'Rome'],
'Type': ['House', '#', 'Car', '#', '#'],
'Vector': ['Triangle', '', 'Square', '#', '#'],
'Mission': ['Completed,lv5', 'Failed', 'Completed', 'Completed without award', ''],
'Note user': ['#', '#', '', 'No end', 'There are many mistake.I cant choose.I cant buy.']
}
df = pd.DataFrame (data, columns=['ID', 'Name', 'Type', 'Vector', 'Mission', 'Note user'])
df
ID Name Type Vector Mission Note
A0001 John House Triangle Completed,lv5 #
A0002 Micheal # Failed #
A0003 Angle Car Square Completed
A0004 Jim # # Completed without award No end
A0005 Rome # # There are many mistake.I cant choose.I cant buy.
您可以使用regex获得答案。附件中附有文件链接
首先,我用
''
替换所有\n
。这样,所有换行符都将从Details
列中删除然后我抓取两个关键字之间的所有文本。 对于类型,数据介于
'Type:'
和'Vector:'
之间。矢量和任务也是如此。注意,我正在抓取'Note user:'
之后的所有数据。现在已经从Details
列中提取了数据,可以删除该列了其输出将为:
以下是我尝试的:
Details
中的第一个值是:我编写这个函数是为了将细节提取到
dict
中。我对数组的索引进行了硬编码,但如果愿意,您可以选择不这样做:将函数应用于整个列:
将此新列连接到原始列:
相关问题 更多 >
编程相关推荐