ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

搜索
EH技术汇-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 效率神器,一键搞定繁琐工作
HR薪酬管理数字化实战 Excel 2021函数公式学习大典 Excel数据透视表实战秘技 打造核心竞争力的职场宝典
让更多数据处理,一键完成 数据工作者的案头书 免费直播课集锦 ExcelHome出品 - VBA代码宝免费下载
用ChatGPT与VBA一键搞定Excel WPS表格从入门到精通 Excel VBA经典代码实践指南
查看: 633|回复: 5

[求助] 如何用PQ进行汇总

[复制链接]

TA的精华主题

TA的得分主题

发表于 2021-11-1 20:03 | 显示全部楼层 |阅读模式
image.png
突发奇想,上午的一个帖子能否用PQ解决?原贴:https://club.excelhome.net/thread-1604613-1-1.html

如何用PQ进行汇总111.rar

7.04 KB, 下载次数: 8

TA的精华主题

TA的得分主题

发表于 2021-11-1 21:08 | 显示全部楼层
这倒不是什么奇想,典型“中国式报表”思维而已,把该放的不该放的都挤在一起。

微软把PQ和DAX集成在PBI里显然是经过考量的,很多统计功能二者都能实现,但显然二者的分工却是非常明确。

你说的这些统计PQ不是不能实现,是不如DAX来得简洁,DAX就是为了“筛选-聚合”而生的。

  1. let
  2.     Source = Table.FromRows(Json.Document(Binary.Decompress(Binary.FromText("i45Werqh/9ncPiUdJUN9Q30jAyNDENPAwEApVgcs+byvGyxpBJM0MkVIPt2zACxpDNeJJAkx1gghaWSAKWkBk7RAN9VI3xImZ4xFo6EB3E4jdK3GSHYaoms1RtJqBLY1FgA=", BinaryEncoding.Base64), Compression.Deflate)), let _t = ((type nullable text) meta [Serialized.Text = true]) in type table [Name = _t, Date = _t, Qty = _t]),
  3.     #"Changed Type" = Table.TransformColumnTypes(Source,{{"Name", type text}, {"Date", type date}, {"Qty", Int64.Type}}),
  4.     #"Sorted Rows" = Table.Sort(#"Changed Type",{{"Name", Order.Ascending}, {"Date", Order.Ascending}}),
  5.     #"Grouped by Month" = Table.Group(#"Sorted Rows", {"Name", "Date"}, {"Count", Table.RowCount}, 0, (x,y) => Number.From(Date.Month(x[Date])<>Date.Month(y[Date]))),
  6.     #"Grouped by Name" = Table.Group(#"Grouped by Month", "Name", {"Rmk", each let rs=Table.ToRecords(_) in Text.Combine(List.Transform(rs, each Date.ToText([Date], "yyyy年M月"&": "&Text.From([Count]))), ", ") & " | 总计: " & Text.From(List.Sum([Count]))})
  7. in
  8.     #"Grouped by Name"
复制代码
image.png

TA的精华主题

TA的得分主题

发表于 2021-11-1 21:32 | 显示全部楼层
如何用PQ进行汇总.rar (14.88 KB, 下载次数: 10)
抛砖引玉吧

TA的精华主题

TA的得分主题

 楼主| 发表于 2021-11-2 09:23 | 显示全部楼层
谢谢给位的无私指教!

TA的精华主题

TA的得分主题

发表于 2021-11-2 19:24 | 显示全部楼层
用PQ做的话其实逻辑不复杂 只是合并各种类型数据有点烦

TA的精华主题

TA的得分主题

 楼主| 发表于 2021-11-3 16:13 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
let
    Source = Table.FromRows(Json.Document(Binary.Decompress(Binary.FromText("i45Werqh/9ncPiUdJUN9Q30jAyNDENPAwEApVgcs+byvGyxpBJM0MkVIPt2zACxpDNeJJAkx1gghaWSAKWkBk7RAN9VI3xImZ4xFo6EB3E4jdK3GSHYaoms1RtJqBLY1FgA=", BinaryEncoding.Base64), Compression.Deflate)), let _t = ((type nullable text) meta [Serialized.Text = true]) in type table [Name = _t, Date = _t, Qty = _t]),


我的数据如何转换成"i45Werqh/9ncPiUdJUN9Q30jAyNDENPAwEApVgcs+byvGyxpBJM0MkVIPt2zACxpDNeJJAkx1gghaWSAKWkBk7RAN9VI3xImZ4xFo6EB3E4jdK3GSHYaoms1RtJqBLY1FgA=" base64编码?
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

手机版|关于我们|联系我们|ExcelHome

GMT+8, 2024-11-16 02:32 , Processed in 0.035445 second(s), 12 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

沪公网安备 31011702000001号 沪ICP备11019229号-2

本论坛言论纯属发表者个人意见,任何违反国家相关法律的言论,本站将协助国家相关部门追究发言者责任!     本站特聘法律顾问:李志群律师

快速回复 返回顶部 返回列表