首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

PQ又一新陷阱:分组加的列,哪儿去了?

1 今天,微信群里有位朋友说,参照我以前写的文章,通过分组的方法对自己的数据分组加索引,新加的索引列(Index)却不存在: 其实,如果大家仔细对比一下我文章里的步骤公式和现在生成的公式的话...以前(Excel2016)做分组的时候,生成的公式后面只有一个"type table": 而现在(Office365)做分组的时候,生成的公式最后的"type table"后面,还多了一长串...: 也就是说,较新版本(不同版本的情况有些差异)的Power Query里的分组操作会自动带上原表中所有字段的类型代码!...如果前面看过我的视频《PQ里的操作陷阱》,可能就比较容易想得到,正是由于多出来的这段类型代码,导致自己新加的列出不来。...知道问题的所在,解决起来就简单了,方法有两个: 1、删掉类型代码的内容: 2、在转换类型里加上新加的字段且声明其类型:

77820

按照A列进行分组并计算出B列每个分组的平均值,然后对B列内的每个元素减去分组平均值

一、前言 前几天在Python星耀交流群有个叫【在下不才】的粉丝问了一个Pandas的问题,按照A列进行分组并计算出B列每个分组的平均值,然后对B列内的每个元素减去分组平均值,这里拿出来给大家分享下,一起学习...888] df = pd.DataFrame({'lv': lv, 'num': num}) def demean(arr): return arr - arr.mean() # 按照"lv"列进行分组并计算出..."num"列每个分组的平均值,然后"num"列内的每个元素减去分组平均值 df["juncha"] = df.groupby("lv")["num"].transform(demean) print(df...df.groupby('lv')["num"].transform('mean') df["juncha"] = df["num"] - df["gp_mean"] print(df) # 直接输出结果,省略分组平均值列...这篇文章主要分享了Pandas处理相关知识,基于粉丝提出的按照A列进行分组并计算出B列每个分组的平均值,然后对B列内的每个元素减去分组平均值的问题,给出了3个行之有效的方法,帮助粉丝顺利解决了问题。

3K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    分组后合并分组列中的字符串如何操作?

    一、前言 前几天在Python最强王者交流群【IF】问了一个Pandas的问题,如图所示。...下面是他的原始数据: 序号 需求 处理人 1 优化 A 2 优化 B 3 运维 A 4 运维 C 5 需求 B 6 优化 C 7 运维 B 8 运维 C 9 需求 C 10 运维 C 11 需求 B...如果不去重,就不用unique,完美地解决粉丝的问题! 后来他自己参考月神的文章,拯救pandas计划(17)——对各分类的含重复记录的字符串列的去重拼接,也写出来了,如图所示。...这篇文章主要盘点了一个pandas的基础问题,文中针对该问题给出了具体的解析和代码实现,帮助粉丝顺利解决了问题。...最后感谢粉丝【IF】提问,感谢【月神】、【瑜亮老师】给出的思路和代码解析,感谢【dcpeng】等人参与学习交流。

    3.3K10

    Pandas基础:列方向分组变形

    刚才碰到一个非常简单的需求: ? 但是我发现大部分人在做这个题的时候,代码写的异常复杂。所以我建议你也不要直接看我的代码,而是先思考一下,你会怎么解决这个问题。...为了后续处理方便,我将不需要参与分组的第一列事先设置为索引。 groupby分组相信大部分读者都使用过,但一直都是按行分组,不过groupby不仅可以按行分组,还可以按列进行分组。...即可作为分组依据,axis=1则指定了groupby按列进行分组而不是默认的按行分组。...split.rename(columns=lambda s: s[5:], inplace=True) 表示对分组后的结果去除列名的前5个字符。...split.reset_index(inplace=True) 表示还原索引为普通的列。 split["年份"] = year 将年份添加到后面单独的一列。

    1.4K20

    【技巧】如何快速按照日期分组

    问题的提出 在处理数据的时候,我们常常需要按照日期对数据进行分类汇总,例如每周、每月、每年汇总等。常见的做法是建立一个用于分类的变量,然后再按照这个变量进行汇总。...再次,这种常规方法很难处理一些不规则的日期间隔,例如我希望每隔3天对数据汇总一次;或者再变态一点,我希望把数据分成两组:一组是周三,另一组是非周三。遇到这种情况,我们该怎么办呢?...按照“是否为周三”进行分类 如果我们想把样本分成两组,一组是周三(True),一组是非周三(False),则只要使用 wday(date)==3来生成一列值为 True或者 False的向量就行。...# 按照是否为“周三”进行分组:“True”即周三,“False”即除周三以外的任何日期 dt[, .(x = mean(x)), keyby = ....# 按照“每3天”进行分组 dt[, .(x = mean(x)), keyby = .

    2.5K30

    盘点一个Pandas多列分组问题

    一、前言 前几天在Python白银交流群【在途中要勤奋的熏肉肉】问了一道Pandas处理的问题,如下图所示。...原始数据如下图所示: 下面是她自己写的代码: # df['name'] = df['name'].str.lower() test['pid'] = test['pid'].astype(int) test...'-'.join(set(s)), } testdf = test.groupby(test['pid']).aggregate(aggregate_funcs) print(testdf) 目前的大概思路如下...顺利地解决了粉丝的问题。 三、总结 大家好,我是皮皮。这篇文章主要盘点了一道使用Pandas处理数据的问题,文中针对该问题给出了具体的解析和代码实现,帮助粉丝顺利解决了问题。...最后感谢粉丝【在途中要勤奋的熏肉肉】提问,感谢【月神】给出的思路和代码解析,感谢【dcpeng】、【猫药师Kelly】等人参与学习交流。

    1.2K10

    PLSQL常用函数(日期、字符、数字、转换、其他、分组)

    --sysdate为系统日期 dual为虚表 --2.last_day [返回该月最后一天的日期] --select last_day(sysdate) from dual; --3.months_between...[返回日期之间的月份数] --4.next_day(d,day): 返回下个星期的日期,day为1-7或星期日-星期六,1表示星期日 --5....,round舍入到最接近的日期 --6.trunc[截断到最接近的日期] --7.返回日期列表中最晚日期 --select greatest('01-1月-04','04-1月-04','10-2月-...ex1,ex2): 值相等返空,否则返回第一个值 --5.coalesce:返回列表中第一个非空表达式 --6.nvl2(ex1,ex2,ex3) 如果ex1不为空,显示ex2,否则显示ex3 --六、分组函数...--max min avg count sum --1.整个结果集是一个组 --2.带group by 和 having 的分组 --3.tddev 返回一组值的标准偏差,variance 返回一组值的方差差

    2K20

    JavaScript 的新数组分组方法

    对数组中的项目进行分组,你可能已经做过很多次了。每次都会手动编写一个分组函数,或者使用 lodash 的 groupBy 函数。...以前的做法 假设你有一个代表人的对象数组,你想按年龄对它们进行分组。...使用Object.groupBy 有了新的 Object.groupBy 方法,你就可以像这样得出结果: const peopleByAge = Object.groupBy(people, (person...根据该提案,有一个库曾经用一个不兼容的 groupBy 方法对 Array.prototype 进行了猴子补丁。在考虑新的应用程序接口时,向后兼容性非常重要。...当 Record 和 Tuples 提议实现时,我们可以添加一个 Record.groupBy 方法,用于将数组分组为不可变的记录。 总结 将项目分组显然是我们开发人员的一项重要工作。

    31810

    Java 8 新特性(三)新的日期时间类

    这些问题都在新日期时间类中得到了解决。 新日期时间类 Java 8引入了三个新的日期时间类,分别是LocalDate、LocalTime和LocalDateTime,分别处理日期、时间和日期时间。...dateTime); LocalDate birthday = LocalDate.of(1994, Month.JANUARY, 18); 日期运算 新类附带了很多新的日期运算方法,可以帮助我们进行很多计算...新的Java 8 中专门有一个类对这个参数进行了抽象,这就是Instant类,而且把精确度提高到纳秒级别。 新老日期转换 Instant类一般不单独使用,比较常见的用法就是在新老日期键进行转换。...运行这个例子可以看到,现在新的JDBC驱动都可以直接将新日期对象存入数据库,并且可以直接取出。...以上就是Java 8 对于新的日期时间类的内容。这些类可以帮助我们轻松处理时间有关问题。如果不是处理老旧项目的话,我们最好都是用这些新类,享受它们带给我们的便利。

    1.4K50

    JDBC日期和新的JDK8 日期API转换问题

    网上的Java博客,凡是有几年的,而且有关于日期的地方,基本上用的都是java.util.Date这个类。...在新的JDK8中引入了一组全新的日期时间类,在java.time包下,具体用法我就不说了。这些新类包含了很多新方法,功能比旧类更强大、更完善。所以现在我们的新程序,都应该使用这些新的API。...旧的java.util.Date应该完全不用。 但是在JDBC中,新的类好像没有反映出来。...java.sql.Date这个类已经做出了一些改变,我们如果查看它的Java Doc话就会发现它在JDK1.8中增加了几个方法,来适应新API和自己的转换,这两个方法是 toLocalDate()和valueOf...在JDBC4.2规范中,我们甚至都不需要java.sql.Date类了,可以直接将LocalDate这些新类直接和PreparedStatement和ResultSet绑定,这需要通过setObject

    61010

    Java8新特性:新的日期和时间 API

    参考Java8新特性:默认方法 新的日期和时间 API:JDK 8 中新增了一个全新的日期和时间 API,它提供了更为丰富的日期和时间处理功能。...这可以让您更轻松地处理日期和时间数据,提高代码的可阅性。 新的日期和时间 API Java 8 中引入了新的日期和时间 API,它是基于 JSR 310 标准而设计的。...此外,新的日期和时间 API 还提供了很多实用的工具类,用于处理日期和时间。...新的日期和时间 API 也提供了丰富的工具类,用于处理日期和时间的不同维度,如时间段、日期段、时区等。...如果需要向后兼容旧的代码,可以继续使用传统的日期和时间 API,但如果需要编写新的代码,建议使用新的日期和时间 API。

    14810

    forestploter: 分组创建具有置信区间的多列森林图

    下面是因INFORnotes的分享 与其他绘制森林图的包相比,forestploter将森林图视为表格,元素按行和列对齐。可以调整森林图中显示的内容和方式,并且可以分组多列显示置信区间。...森林图的布局由所提供的数据集决定。 基本的森林图 森林图中的文本 数据的列名将绘制为表头,数据中的内容将显示在森林图中。应提供一个或多个不带任何内容的空白列以绘制置信区间(CI)。...", theme = tm) # Print plot plot(pt) 编辑森林图 edit_plot可用于更改某些列或行的颜色或字体。...如果提供的est、lower和upper的数目大于绘制CI的列号,则est、lower和upper将被重用。如下例所示,est_gp1和est_gp2将画在第3列和第5列中。...但是est_gp3和est_gp4还没有被使用,它们将再次被绘制到第3列和第5列。

    9K32
    领券