- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
已经问了很多类似的类似问题,这对我解决这个问题有很大帮助,我遵循了以下帮助: Fill in missing dates of groupby和 Pandas- adding missing dates to DataFrame while keeping column/index values?
然而它仍然没有发挥作用。
我制作了一个玩具数据集来演示我面临的问题:
data = pd.DataFrame({'Date': ['2012-01-01', '2012-01-01','2012-01-01','2012-01-02','2012-01-02','2012-01-02','2012-01-03'], 'Id': ['21','21','22','21','22','23','21'], 'Quantity': ['5','1','4','4','2','1','4'], 'NetAmount': ['66','45','76','35','76','73','45']})
data['Quantity'] = data['Quantity'].astype('int')
data['NetAmount'] = data['NetAmount'].astype('float')
我按照下面的代码对数据集进行了分组:
data['Date'] =pd.to_datetime(data.Date) - pd.to_timedelta(7,unit = 'd')
data =data.groupby(['Id',pd.Grouper(key='Date', freq='W-MON')])['Quantity', 'NetAmount'].sum().reset_index().sort_values('Date')
data.reset_index()
data1 = data.groupby(['Id','Date']).agg({'Quantity': sum, 'NetAmount': sum}).reset_index()
然后我填写缺失的日期:
data2 = data1.set_index(['Date', 'Id','NetAmount']).Quantity.unstack(-3).\
reindex(columns=pd.date_range(data1['Date'].min(), data1['Date'].max(),freq='W-MON'),fill_value=0).\
stack(dropna=False).unstack().stack(dropna=False).\
unstack('NetAmount').stack(dropna=False).fillna(0).reset_index()
给出结果数据框:
Id level_1 NetAmount 0
0 21 2011-12-26 45.0 0.0
1 21 2011-12-26 73.0 0.0
2 21 2011-12-26 146.0 10.0
3 21 2011-12-26 152.0 0.0
4 21 2012-01-02 45.0 4.0
5 21 2012-01-02 73.0 0.0
6 21 2012-01-02 146.0 0.0
7 21 2012-01-02 152.0 0.0
8 22 2011-12-26 45.0 0.0
9 22 2011-12-26 73.0 0.0
10 22 2011-12-26 146.0 0.0
11 22 2011-12-26 152.0 6.0
12 22 2012-01-02 45.0 0.0
13 22 2012-01-02 73.0 0.0
14 22 2012-01-02 146.0 0.0
15 22 2012-01-02 152.0 0.0
16 23 2011-12-26 45.0 0.0
17 23 2011-12-26 73.0 1.0
18 23 2011-12-26 146.0 0.0
19 23 2011-12-26 152.0 0.0
20 23 2012-01-02 45.0 0.0
21 23 2012-01-02 73.0 0.0
22 23 2012-01-02 146.0 0.0
23 23 2012-01-02 152.0 0.0
但实际上我希望得到:
0 21 2011-12-26 66.0 5.0
1 21 2011-12-26 45.0 1.0
2 21 2011-12-26 35.0 4.0
3 21 2012-02-02 45.0 4.0
4 22 2011-12-26 76.0 4.0
5 22 2012-02-02 76.0 2.0
6 23 2011-12-26 0.0 0.0
7 23 2012-02-02 73.0 1.0
填充有效,但是,我不明白结果数据框中到底发生了什么,例如在 netAmount 列中,结果是关闭的我是 unstack/stack 函数的新手,我在这个过程中遗漏了什么?感谢您的帮助!
更新:我尝试在添加“0”值后按 id 和数据重新分组:
data2 = pd.DataFrame(data2)
data3 = data2.groupby(['Id','Date']).agg({'Quantity': sum, 'NetAmount': sum}).reset_index()
但是我得到了这个错误
Traceback (most recent call last):
File "", line 48, in <module>
data3 = data2.groupby(['Id','Date']).agg({'Quantity': sum, 'NetAmount': sum}).reset_index()
File "", line 7632, in groupby
observed=observed, **kwargs)
File "", line 2110, in groupby
return klass(obj, by, **kwds)
File "", line 360, in __init__
mutated=self.mutated)
File "", line 578, in _get_grouper
raise KeyError(gpr)
KeyError: 'Date'
最佳答案
您需要将列 Quantity
和 NetAmount
转换为数字
data['Quantity'] = data['Quantity'].astype('int')
data['NetAmount'] = data['NetAmount'].astype('float')
当列为字符串时,sum 函数按组连接所有字符串。
现在重新运行您的代码,它应该会按预期工作
# Id level_1 NetAmount 0
#0 21 2011-12-26 45.0 0.0
#1 21 2011-12-26 73.0 0.0
#2 21 2011-12-26 146.0 10.0
#3 21 2011-12-26 152.0 0.0
#4 21 2012-01-02 45.0 4.0
#5 21 2012-01-02 73.0 0.0
#6 21 2012-01-02 146.0 0.0
#7 21 2012-01-02 152.0 0.0
#8 22 2011-12-26 45.0 0.0
#9 22 2011-12-26 73.0 0.0
#10 22 2011-12-26 146.0 0.0
#11 22 2011-12-26 152.0 6.0
#12 22 2012-01-02 45.0 0.0
#13 22 2012-01-02 73.0 0.0
#14 22 2012-01-02 146.0 0.0
#15 22 2012-01-02 152.0 0.0
#16 23 2011-12-26 45.0 0.0
#17 23 2011-12-26 73.0 1.0
#18 23 2011-12-26 146.0 0.0
#19 23 2011-12-26 152.0 0.0
#20 23 2012-01-02 45.0 0.0
#21 23 2012-01-02 73.0 0.0
#22 23 2012-01-02 146.0 0.0
#23 23 2012-01-02 152.0 0.0
关于python - 填充缺失日期后在 pandas groupby 对象中填充值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58494858/
我编写了一个 Android 应用程序,它使用 Azure 来执行用户通过 Google、Twitter 和 Facebook 的登录;它使用 Microsoft.WindowsAzure.Mobil
我想将 AdomdClient 引用添加到 C# 项目,但它不在引用列表中。客户端列在程序集文件夹 C:\Windows\Assembly 中。 计算机上安装了 SQL Server 2012。 最佳
我正在学习“绘图应用程序”的教程。当我在 Firefox 上启动我的应用程序时,Firebug 告诉我“在语句之前缺少 ;” 我在第 9 行调用函数的位置。我只是不明白应该将这些“;”放在哪里. va
我想将 AdomdClient 引用添加到 C# 项目,但它不在引用列表中。客户端列在程序集文件夹 C:\Windows\Assembly 中。 计算机上安装了 SQL Server 2012。 最佳
我在 Firebug 中不断收到关于 onClick 事件的错误。 我已经尝试了 "和 ' 的各种不同组合,但无济于事。在添加 onClick 事件之前,这工作正常。 有人能发现我可能做错了什么吗?
Visual Studio 2015 告诉我找不到 WSASetSocketSecurity。 该 dll 存在并且还包括似乎没问题。 我的包括: windows.h stdio.h Wincrypt
我需要访问 eloquent 的 whereHasNot方法(此处添加: https://github.com/laravel/framework/commit/8f0cb08d8ebd157cbfe
跟随宠物物体检测的 TF 教程:https://github.com/tensorflow/models/blob/master/research/object_detection/g3doc/run
构建路径 > 添加库 > JUnit 无法添加 JUnit3 或 JUnit4 组件。 我在.log 中看到这样的消息 !MESSAGE No property tester contributes
我正在运行此脚本来查看网络上的摄像机: gst-launch udpsrc port=1234 ! "application/x-rtp, payload=127" ! rtph264depay !
我正在使用http://java.sun.com/jsp/jstl/fmt用于从 Spring 配置中设置的 Message Resource Bundle 输出消息的标签库。消息解析也可以放在 Co
我正在将 Ninject 与 MVC4 连接起来,并让它工作到尝试实际解决依赖关系的程度。但是,我收到以下异常: Method not found: 'System.Web.Http.Services
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 这个问题似乎与 help center 中定义的范围内的编程无关。 . 关闭 9 年前。 Improve
我在启动 ASP.NET MVC5 应用程序时遇到问题。到目前为止一切正常。启动应用程序时出现以下错误: Could not load file or assembly 'Microsoft.Appl
我已经使用以下方法创建了一个环境: conda create --prefix C:\Users\Dell\Dropbox\DjangoProjects\webenv python=3.6 执行后:c
我们有一个遗留的 Web 窗体应用程序,我们最近将其从网站项目转换为 Web 应用程序项目。 Web 窗体项目是解决方案的“启动”项目。 有一个 MVC 项目是对 Web 窗体项目的引用。 在 MVC
使用某种字体,我使用Java的FontLayout来确定它的上升、下降和行距。 (参见 Java 的 FontLayout 教程 here) 在我的具体案例中,我使用的是 Arial Unicode
我正在尝试在 linux 下编译 qt ffmpeg 包装器简单编码/解码示例 QTFFmpegWrapper source # Set list of required FFmpeg librari
我正在使用来自开发人员 android 页面的 SlidingTabLayout.java。在我使用 slidingTabLayout.setDistributeEvenly(true); 使 sli
我正在尝试使用 v360 filter 将 180° 鱼眼视频转换为普通/常规视频的 FFmpeg . 这是我尝试过的命令:ffmpeg -i in.mp4 -vf "v360=input=fishe
我是一名优秀的程序员,十分优秀!