草庐IT

pandas-explode

全部标签

python - 列 : getting value_counts as columns in pandas 的多级索引

在一般意义上,我要解决的问题是将多级索引的一个组件更改为列。也就是说,我有一个包含多级索引的Series,我希望索引的最低级别更改为dataframe中的列。这是我试图解决的实际示例问题,这里我们可以生成一些示例数据:foo_choices=["saul","walter","jessee"]bar_choices=["alpha","beta","foxtrot","gamma","hotel","yankee"]df=DataFrame([{"foo":random.choice(foo_choices),"bar":random.choice(bar_choices)}for_i

python - pandas - 数据框中出现的唯一行数

如何计算DataFrame中每个唯一行的出现次数?data={'x1':['A','B','A','A','B','A','A','A'],'x2':[1,3,2,2,3,1,2,3]}df=pd.DataFrame(data)dfx1x20A11B32A23A24B35A16A27A3我想得到x1x2count0A121A232A313B32 最佳答案 IIUC您可以将参数as_index=False作为参数传递给groupby:In[100]:df.groupby(['x1','x2'],as_index=False).coun

python - 从 pandas 转换为 numpy 时如何保留列名

根据tothispost,我应该能够访问ndarray中列的名称作为a.dtype.names但是,如果我使用df.as_matrix()或df.values将pandasDataFrame转换为ndarray,则dtype.names字段为None。此外,如果我尝试将列名分配给ndarrayX=pd.DataFrame(dict(age=[40.,50.,60.],sys_blood_pressure=[140.,150.,160.]))printXprinttype(X.as_matrix())#printtype(X.as_matrix()[0])#m=X.as_matrix()

python - Pandas 加入具有不同名称的列

这个问题在这里已经有了答案:PandasMerging101(8个答案)关闭3年前。我有两个不同的数据框,我想对其执行一些sql操作。不幸的是,就像我正在处理的数据一样,拼写通常不同。请参阅下面的示例,其中我认为语法看起来像用户ID属于df1,用户名属于df2。有人帮帮我吗?#notworking-Iassumesomesyntaxissue?pd.merge(df1,df2,on=[['userid'=='username','column1']],how='left')

python - pandas groupby 计数、总和和平均值

我在Pandas中有以下DF:+---------+--------+--------------------+|keyword|weight|otherkeywords|+---------+--------+--------------------+|dog|0.12|[cat,horse,pig]||cat|0.5|[dog,pig,camel]||horse|0.07|[dog,camel,cat]||dog|0.1|[cat,horse]||dog|0.2|[cat,horse,pig]||horse|0.3|[camel]|+---------+--------+-----

python - 具有每列模式的多列 Pandas Fillna

处理人口普查数据时,我想用这两列各自的模式替换两列(“workclass”和“native-country”)中的NaN。我可以轻松获得这些模式:mode=df.filter(["workclass","native-country"]).mode()它返回一个数据框:workclassnative-country0PrivateUnited-States但是,df.filter(["workclass","native-country"]).fillna(mode)不会用任何东西替换每列中的NaN,更不用说与该列对应的模式了。有没有一种流畅的方法可以做到这一点?

python - 在 pandas 中使用 groupby 进行 bool 运算

我想以特定方式使用pandas.groupby。给定一个包含两个bool列(分别称为col1和col2)和一个id列的DataFrame,我想按以下方式添加一列:对于每个条目,如果(col2为True)并且(col1对于任何具有相同ID的条目为True)则分配True。否则为假。我做了一个简单的例子:df=pd.DataFrame([[0,1,1,2,2,3,3],[False,False,False,False,False,False,True],[False,True,False,False,True,True,False]]).transpose()df.columns=['id

python - 寻找整个 Pandas 数据框的中位数

我试图找到整个数据帧的中值流。第一部分是仅选择数据框中的某些项目。这有两个问题,它包括不在“状态”中的数据框部分。此外,中位数不是单个值,它基于行。我将如何获得数据框中所有数据的总体中位数? 最佳答案 两种选择:1)Pandas选项:df.stack().median()2)一个numpy选项:np.median(df.values) 关于python-寻找整个Pandas数据框的中位数,我们在StackOverflow上找到一个类似的问题: https://

python - 如何在 pandas 0.20.1+ 中重命名多级分组中的所有列

随着Pandas0.20.1的发布,对groupby.agg()的功能进行了新的弃用,其中包含用于重命名的字典。Deprecationdocumentation我正在尝试找到更新我的代码以解决这个问题的最佳方法,但是我正在努力解决我目前如何使用此重命名功能。当我进行聚合时,我经常为每个源列设置多个函数,并且我一直在使用此重命名功能来获得具有这些新列名称的单级索引。例子:df=pd.DataFrame({'A':[1,1,1,2,2],'B':range(5),'C':range(5)})In[30]:dfOut[30]:ABC01001111212232334244frame=df.g

python - 在 Pandas 中查找数字列名称

我需要在Pandas中选择列名称中仅包含数值的列,例如:df=01234window_labelnext_statesids017.018.016.015.015.0dddddd13.0118.016.015.015.016.0dddddd13.0216.015.015.016.015.0dddddd13.0315.015.016.015.017.0dddddd13.0415.016.015.017.0NaNdddddd13.0所以我只需要选择前五列。像这样的东西:df[df.columns.isnumeric()]编辑我想到了解决方案:digit_column_names=[numf