- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有这些数据:
# df
ID Col1
A -4
A -3
A -2
A -1
A 1
A 2
A 9992
B -4
B -3
B -2
B -1
B 9
B 13
B 21
B 38
B 9992
我想创建一个新列 Col_NEW
,并基于 Col1
按 ID
进行前向填充或滚动计算。
最终结果:
# df
ID Col1 Col_NEW
A -4 -4
A -3 -3
A -2 -2
A -1 -1
A 1 0
A 2 2
A 9992 3
B -4 -4
B -3 -3
B -2 -2
B -1 -1
B 9 0
B 13 10
B 21 14
B 38 22
B 9992 39
逻辑如下:
Col
为-4
、-3
、-2
、-1
code> ,则 Col_NEW
是相同的。Col_NEW
将是 Col1
前向填充并加 1。我尝试过这个,但是有没有办法直接创建Col_NEW
?
df["Col_NEW"] = df.groupby('ID')['Col1'].transform(lambda x: (x.shift(1) + 1))
有什么想法吗?
最佳答案
像这样,没有任何apply
或任何其他迭代:
retain_mask = df['Col1'].isin([-4,-3,-2,-1])
df["Col_NEW"] =df.groupby('ID')['Col1'].shift()+1
df.loc[retain_mask,"Col_NEW"] = df.loc[retain_mask,'Col1']
输出:
ID Col1 Col_NEW
-- ---- ------ ---------
0 A -4 -4
1 A -3 -3
2 A -2 -2
3 A -1 -1
4 A 1 0
5 A 2 2
6 A 9992 3
7 B -4 -4
8 B -3 -3
9 B -2 -2
10 B -1 -1
11 B 9 0
12 B 13 10
13 B 21 14
14 B 38 22
15 B 9992 39
where
同样的想法,稍微简洁一点:
retain_mask = df['Col1'].isin([-4,-3,-2,-1])
df["Col_NEW"] = df['Col1'].where(retain_mask, df.groupby('ID')['Col1'].shift()+1)
关于python - pandas 有条件地按组移动或向前填充另一列,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/70993919/
我正在使用以下键存储哈希集:measurement: , f.e. measurement:1482236501103 ,然后在稍后我想传递某个时间戳并获取从给定时间戳到结束的所有记录。但由于 Red
有 Home.vue 和 Statistics.vue 页面。 Home.vue 渲染 TableFields.vue 组件。在 Home.vue 中,有一些字段编号,在页面加载时设置了初始值“3”。
Spring MVC ModelAndView forward 不工作。下面的代码没有将请求转发到 Name.jsp。非常感谢您的帮助。 package main.java.com.mkyong.co
我有一个这样的值列表, lst = [1, 2, 3, 4, 5, 6, 7, 8] 期望输出 : window size = 3 1 # first element in the list
我正在尝试将硬币类移动到按下键时的适当元素。但是,如果元素的名称相似,我不确定如何正确导航 DOM 树。另外,我根据按下键(e.which)向上/向下移动,但如果硬币在某些地方,我需要旋转回到顶部或底
我需要制作一个不循环的幻灯片,但实际上在幻灯片之间弹跳:例如,如果我有 3 张幻灯片,我希望幻灯片顺序为: 1 -> 2 -> 3 -> 2 -> 1 -> 2 ... 我想出了这个解决方案(使用 j
我只想获取下一次迭代中的元素(使用基于范围的 for 循环) 我试过类似的东西: *(&x+1) 应该表示“i+1”,如果“i”在这里是一个迭代器的话 bool factorChain(std::ve
我有一个 slider ,其可能值在 0 到 1 之间,步长为 0.1 例如,如果我在起点移动 slider ,动画将从 (0%) 开始,如果我将 slider 移动到 0.5 ( 50%) 表示将从
这个问题在这里已经有了答案: python time subtraction (1 个回答) 关闭 9 年前。 我想实现的很简单: time.time() 不太可读。如何获得: 例如 time.ti
如何在 html 中显示此 ► 播放(向前)或向右实心箭头符号? 最佳答案 是的,►,但它在所有浏览器中看起来可能不一样。 关于html - 如何在 html 中显示 ► 播放(向前)或向右实心箭头符
我正在开发 wpf c# 应用程序,我需要检测用户何时按下“/ ” 但我找不到“/ ” e.Key,我看到有Key.OemBackslash和类似的东西,但我找不到“/”(正斜杠)的正确事件.....
我有两个数据集,(dt1) 一个带有“开始”日期,每个 ID 最多两个条目(因为这些是 L 或 R 眼手术的条目)和一个 (dt2) 第二个数据库,其中包含多个日期之前和之后开始日期。这些不仅限于眼科
我有使用 3 个欧拉 Angular (aRotX、aRotY、aRotZ)在其位置(aX、aY、aZ)显示模型的代码: var m = mat4.create(); mat4.identity(m)
我需要从方向 vector (vForward) 获取旋转矩阵 我还有 vRight 和 vUp vector 。所有这些 vector 都是单位 vector 。 我只需要得到旋转矩阵。 要获得仅在
我是一名优秀的程序员,十分优秀!