python – 使用pandas对csv进行排序和分组

我导入一个包含以下内容的CSV文件

Id; PartNrInt; Some; other; stuff;
R1; 1234-5678; x1; y1; z1;
R2; 1234-6789; x2; y2; z2;
R3; 1234-5678; x3; y3; z3;

然后我有一个数据库,其中包含每个PartNrInt的附加数据.我合并了这两个数据帧,所以我有这样的事情:

Id; PartNrInt; OrderNr; Manufacturer; Some; other; stuff;
R1; 1234-5678; OrderNr1; Manuf1; x1; y1; z1;
R2; 1234-6789; OrderNr2: Manuf2; x2; y2; z2;
R3; 1234-5678; OrderNr1: Manuf1; x3; y3; z3;

这部分工作正常,我可以轻松打印数据帧.要在我们的ERP系统中导入文件,我必须按PartNrInt对表进行分组.
所以我想要一张像这样的桌子:

Count; Names; PartNrInt; OrderNr; Manufacturer
2; R1,R3; 1234-5678; OrderNr1; Manuf1
1; R2; 1234-6789; OrderNr1; Manuf1

我的问题是,我可以将数据与df.groupby(‘PartNrInt’)[‘Id’]进行分组.应用(列表)并计算对象,但我无法在新帧中获取新数据以进行导出.
我对熊猫和Python都是新手,所以也许有一个非常简单的解决方案.

解决方法

您可以使用 groupbyaggregate join和len,last reset_index并重新排序列:

df = df.groupby(['PartNrInt','OrderNr','Manufacturer']).Id 
       .agg({"Names": ','.join,'Count': len}) 
       .reset_index()[['Count','Names','PartNrInt','Manufacturer']]
print (df)

   Count  Names  PartNrInt   OrderNr Manufacturer
0      2  R1,R3  1234-5678  OrderNr1       Manuf1
1      1     R2  1234-6789  OrderNr2       Manuf2

相关文章

功能概要:(目前已实现功能)公共展示部分:1.网站首页展示...
大体上把Python中的数据类型分为如下几类: Number(数字) ...
开发之前第一步,就是构造整个的项目结构。这就好比作一幅画...
源码编译方式安装Apache首先下载Apache源码压缩包,地址为ht...
前面说完了此项目的创建及数据模型设计的过程。如果未看过,...
python中常用的写爬虫的库有urllib2、requests,对于大多数比...