码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • BI神器Power Query(25)-- 使用PQ实现表格多列转换(1/3)


    实例需求:原始表格包含多列属性数据,现在需要将不同属性分列展示在不同的行中,att1、att3、att5为一组,att2、att3、att6为另一组,数据如下所示。

    更新表格数据

    原始数据表:

    Col1Col2Att1Att2Att3Att4Att5Att6
    AAADDDXOalphadelta100400
    BBBEEEYPbetavega200500

    结果数据表:

    Col1Col2cn1cn3cn3
    AAADDDXalpha100
    AAADDDOdelta400
    BBBEEEYbeta200
    BBBEEEPvega500

    示例代码:

    let
        Source = Excel.CurrentWorkbook(){[Name="Table1"]}[Content],
        add_index = Table.AddIndexColumn(Source, "Index", 1, 1, Int64.Type),
        tab1 = Table.RemoveColumns(add_index,{"Att2", "Att4", "Att6"}),
        rename_tab1 = Table.RenameColumns(tab1,{{"Att1", "cn1"}, {"Att3", "cn2"}, {"Att5", "cn3"}}),
        tab2 = Table.RemoveColumns(add_index,{"Att1", "Att3", "Att5"}),
        rename_tab2 = Table.RenameColumns(tab2,{{"Att2", "cn1"}, {"Att4", "cn2"}, {"Att6", "cn3"}}),
        combine_tab = Table.Combine({rename_tab1, rename_tab2}),
        sort_row = Table.Sort(combine_tab,{{"Index", Order.Ascending}}),
        output = Table.RemoveColumns(sort_row,{"Index"})
    in
        output
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12

    代码解析:
    第2行代码加载源表格,表格名称为Table1。
    第3行代码添加索引列,用于确保输出结果表的数据顺序于原始表保持一致。
    第4行代码移除多余列,保留部分属性列。
    第5行代码重命名属性列名称。
    第6~7行代码功能类似,用于提取第二组属性。
    第8行代码合并两个子表。
    第9行代码按索引列排序。
    第1行代码移除索引列。
    第12行代码输出最终结果表。

    转换结果如下图所示。

    在这里插入图片描述


    部分代码也可以简化为如下,但是处理逻辑与上面代码相同,上述代码分步处理更容易理解。

    let
        Source = Excel.CurrentWorkbook(){[Name="Table1"]}[Content],
        add_index = Table.AddIndexColumn(Source, "Index", 1, 1, Int64.Type),
        combine_tab = Table.Combine({
            Table.RenameColumns(add_index[[Col1],[Col2],[Att1],[Att3],[Att5],[Index]],{{"Att1","cn1"},{"Att3","cn2"},{"Att5","cn3"}}),
            Table.RenameColumns(add_index[[Col1],[Col2],[Att2],[Att4],[Att6],[Index]],{{"Att2","cn1"},{"Att4","cn2"},{"Att6","cn3"}})
            }),
        sort_row = Table.Sort(combine_tab,{{"Index", Order.Ascending}}),
        output = Table.RemoveColumns(sort_row,{"Index"})
    in
        output
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12

    总结:
    Power Query提供了丰富的表处理功能,可以方便地实现表格列的转换需求。

  • 相关阅读:
    【LearnOpenGL基础入门——2】搭建第一个OpenGL窗口
    能链科技与优得运维携手创新,打通电站金融化数字化之路
    42. 【Android教程】活动:Activity
    80:第七章:开发前台首页、作家个人展示页、粉丝等功能:1:内容概述;(总结了,此前已经开发了的内容;)
    分享在Windows操作系统中独立安装微软MS Access 2019数据库的实用方法
    Ceph存储
    铜九铁十快来上分:vite+ts+vue3搭建你的组件库
    数据库管理系统,数据库,sql的基本介绍以及它们之间的关系
    STM32 定时器定时中断
    杂记-缺失值插值方式
  • 原文地址:https://blog.csdn.net/taller_2000/article/details/133476806
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号