首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在Dataframe中访问字典

在Dataframe中访问字典
EN

Stack Overflow用户
提问于 2018-11-27 11:37:31
回答 2查看 2.8K关注 0票数 2

我有以下数据帧(有1324行):enter image description here

我需要找出哪些城市适合外卖('Take_ out ':属性字典中的True )

EN

回答 2

Stack Overflow用户

发布于 2018-11-27 12:04:04

为了得到这个答案,我首先创建了一个用于测试的虚拟DataFrame:

代码语言:javascript
复制
import numpy as np
import pandas as pd
# create a dictionary list
d = list({'Take-out': True} for x in np.arange(10))
ddf = pd.Series(d, name='attributes')
ddf = pd.DataFrame(ddf)
ddf.index.name = 'cities'
print(ddf)

这将生成一个与您的图像中类似的DataFrame。

接下来,迭代DataFrame,访问“attributes”列,如下所示:

代码语言:javascript
复制
# cities buffer will hold successes
cities = []
# iterate over the list of dictionaries:
for i, each in enumerate(ddf['attributes']):
    # check if the keys is in that dictionary, if so, keep the city name
    if 'Take-out' in ddf['attributes'][i].keys():
        # the index is named 'cities' and each position is a city name, so:
        cities.append(ddf.index[i])
print(cities)
票数 3
EN

Stack Overflow用户

发布于 2018-11-27 11:47:06

字典并不是你真正想要存储在DataFrame中的东西,但是你可以试试:

代码语言:javascript
复制
df = df.assign(**df.attributes.dropna().apply(pd.Series))
df[df["Take_out"] == True]

这与这里描述的思想大致相同:Unpack dictionary from Pandas Column。解开字典后,我们可以像往常一样用"Take_out“== True选择行。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/53492365

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档