Excel的Power Query(简称PQ)是近年来微软重点推荐的一个组件 , 由于它支持的外部数据来源丰富 , 图形化界面功能丰富 , 更支持自定义M函数 , 所以确实是一个数据获取、数据处理的强大工具 。
通过PQ连接数据 → 给PP(Power Pivot)提供丰富的数据 → 建立数据模型 → 输出报表 , 这是微软官方指引的一条技术路径 , 确实值得跟进学习 , PQ目前支持的数据来源包括:
文章插图
【wps表格日期怎么自动生成?】PQ支持的数据源
由上面可以看出 , 微软真的是花了大功夫去打造它 , 未来肯定还会支持更多数据来源 , 确实值得我们跟进学习使用 。当然我们也要结合自己的工作情况 , 如果你公司的版本支持PQ , 不妨趁空余时间学习下 , 但在实际应用时一定要注意版本的兼容性问题 。(自Excel2016开始 , 才真正地支持PQ , 而且如果你是O365的用户 , PQ也会不断迭代新的功能)
我和黄老师经常在很多零售企业做数据咨询项目 , 据我了解 , 对于传统零售行业的朋友来说 , PQ还是一项“新”的功能 , 不少朋友看到上面的数据来源 , 都会一脸懵懂 。但是其实真的问题不大 , 因为也会有其他方法去解决 , 并不是非学不可~~~有时候帮客户去分析几年的数据 , 行数都达几千万行 , 这时我也会用PQ+PP去进行建模处理 , 对于用透视表来进行数据探索分析 , 还是非常高效的 。
在这里也分享我的一个PQ的M函数给大家 , 用于自动生成日期维度表(PP建模必备) , 非常方便高效~虽然在Excel工作表也能做 , 或者用DAX也能做 , 但是我就爱在PQ里实现!
使用方法:在PQ中新建一个【空查询】 , 然后在【视图】打开【高级编辑器】 , 清除原来的内容 , 输入以下内容 , 设置你的起始日期和结束日期 , 点完成就ok了 , 优雅方便高效~希望对大家有帮助!
大家也可以在此基础上调整代码 , 以便获得自己想要的分析维度 。适合在所有PQ版本 , 包括Power BI中 。使用
let// 设置起始日期、结束日期自定义日期区间 = {Number.From(#date(2018,1,1)) .. Number.From(#date(2020,12,31))},转换为表 = Table.FromList(自定义日期区间, Splitter.SplitByNothing(), null, null, ExtraValues.Error),生成日期列 = Table.RenameColumns(转换为表,{{“Column1”, “日期”}}),日期类型 = Table.TransformColumnTypes(生成日期列,{{“日期”, type date}}),整数日期 = Table.AddColumn(日期类型, “IntDate”, each Date.ToText([日期],”yyyyMMdd”)),整数类型1 = Table.TransformColumnTypes(整数日期,{{“IntDate”, Int64.Type}}),年份数 = Table.AddColumn(整数类型1, “YearID”, each Date.Year([日期]), type number),季度数 = Table.AddColumn(年份数, “QuarterID”, each Date.QuarterOfYear([日期]), type number),月份数 = Table.AddColumn(季度数, “MonthID”, each Date.Month([日期]), type number),年月数 = Table.AddColumn(月份数, “yyMMID”, each Text.From([YearID]) & Text.PadStart(Text.From([MonthID]),2,”0″)),整数类型2 = Table.TransformColumnTypes(年月数,{{“yyMMID”, Int64.Type}}),年度周数 = Table.AddColumn(整数类型2, “WeekOfYearID”, each Date.WeekOfYear([日期]), type number),月度日数 = Table.AddColumn(年度周数, “DayID”, each Date.Day([日期]), type number),周星期数 = Table.AddColumn(月度日数, “DayOfWeekID”, each Date.DayOfWeek([日期],1),type number),年份 = Table.AddColumn(周星期数, “年份”, each “Y” & Text.From([YearID]),type text ),季度 = Table.AddColumn(年份, “季度”, each “Q”&Text.From([QuarterID]),type text),月份 = Table.AddColumn(季度, “月份”, each Text.From([MonthID]) & “月”,type text),年月S = Table.AddColumn(月份, “年月S”, each Date.ToText([日期],”yy-MM”),type text),年月S格式 = Table.ReplaceValue(年月S,”-“,”‘”,Replacer.ReplaceText,{“年月S”}),年月L = Table.AddColumn(年月S格式, “年月L”, each Date.ToText([日期],”yyyy年M月”), type text),年周 = Table.AddColumn(年月L, “周”, each “W” & Text.From( [WeekOfYearID] ),type text),月日 = Table.AddColumn(年周, “日”, each “D” & Text.From( [DayID] ),type text),星期 = Table.AddColumn(月日, “星期”, each Date.ToText([日期],”ddd”),type text),调整列顺序 = Table.ReorderColumns(星期,{“日期”, “年份”, “季度”, “月份”, “日”, “星期”, “周”, “年月L”, “年月S”, “IntDate”, “YearID”, “QuarterID”, “MonthID”, “yyMMID”, “WeekOfYearID”, “DayID”, “DayOfWeekID”})in调整列顺序
推荐阅读
- wps怎么打开两个窗口?
- wps批注颜色怎么改?
- wps表格表头怎么固定?
- wps表格怎么填充颜色?
- wps表格索引怎么做?
- wps怎么改变行间距?
- wps自动求和怎么操作
- wps怎么扫描图片?
- wps怎么解除保护?
- wps怎么设置下划线对齐?