当前位置 : 主页 > 编程语言 > python >

# yyds干货盘点 # 该字段对应的内容看上去是个列表字典嵌套,实际上是个str,这

来源:互联网 收集:自由互联 发布时间:2022-10-26
大家好,我是Python进阶者。 一、前言 前几天在Python最强王者交流群【WYM】问了一个​​Pandas​​处理的问题,提问截图如下: 原始数据在​​csv​​文件中了。 二、实现过程 一开始

大家好,我是Python进阶者。

一、前言

前几天在Python最强王者交流群【WYM】问了一个​​Pandas​​处理的问题,提问截图如下:

# yyds干货盘点 # 该字段对应的内容看上去是个列表字典嵌套,实际上是个str,这个字段怎么只取出name对应的内容呢?_python

原始数据在​​csv​​文件中了。

二、实现过程

一开始以为简单的​​eval​​就可以了,后来才知道没那么简单。这里【瑜亮老师】提出使用正则表达式进行提取,​​eval​​还得从列表里面取字典元素,再键值。反正是字符串,直接​​re​​取到想要的数据就行了。这里【瑜亮老师】给了一份代码,如下所示:

import pandas as pd
import re

df = pd.read_csv('test.csv')
df['tblTags'] = df['tblTags'].map(lambda x: re.findall("'name': '(.*?)'", x))
print(df)

运行结果如下所示:

# yyds干货盘点 # 该字段对应的内容看上去是个列表字典嵌套,实际上是个str,这个字段怎么只取出name对应的内容呢?_Pandas_02

如果想要每个标签变成一行,就再取得值后使用explode爆炸函数​​df = df.explode("tblTags")​​。

# yyds干货盘点 # 该字段对应的内容看上去是个列表字典嵌套,实际上是个str,这个字段怎么只取出name对应的内容呢?_Python基础_03

【郑煜哲·Xiaopang】也给了一个思路,首先合并所有​​list​​,然后​​get​​。【隔壁

网友评论