大家好,我是Python进阶者。 一、前言 前几天在Python最强王者交流群【WYM】问了一个Pandas处理的问题,提问截图如下: 原始数据在csv文件中了。 二、实现过程 一开始
大家好,我是Python进阶者。
一、前言
前几天在Python最强王者交流群【WYM】问了一个Pandas处理的问题,提问截图如下:
原始数据在csv文件中了。
二、实现过程
一开始以为简单的eval就可以了,后来才知道没那么简单。这里【瑜亮老师】提出使用正则表达式进行提取,eval还得从列表里面取字典元素,再键值。反正是字符串,直接re取到想要的数据就行了。这里【瑜亮老师】给了一份代码,如下所示:
import pandas as pdimport re
df = pd.read_csv('test.csv')
df['tblTags'] = df['tblTags'].map(lambda x: re.findall("'name': '(.*?)'", x))
print(df)
运行结果如下所示:
如果想要每个标签变成一行,就再取得值后使用explode爆炸函数df = df.explode("tblTags")。
【郑煜哲·Xiaopang】也给了一个思路,首先合并所有list,然后get。【隔壁