PowerQuery 多级目录数据合并,并将目录转化为字段

PowerQuery 多级目录数据合并,并将目录转化为字段
摘要由CSDN通过智能技术生成

实现功能:将Data目录下所有子文件数据合并,并将路径中的信息转化为字段使用

在这里插入图片描述

原始数据如下:
  • Data文件夹下有以地理层级结构存放的销售数据
    在这里插入图片描述
  • Excel文件中各Sheet名为最底层的地理信息,且Sheet数据结构相同
    在这里插入图片描述

实现方式:

  1. 在query端读取文件夹路径信息
= Folder.Files("I:\Data")

结果如下图:红框部分为后续需要关注的字段
在这里插入图片描述

  1. 添加Country字段,利用Folder Path字段解析出Country
= Table.AddColumn(源, "Country", each Text.Split([Folder Path],"\"){3}, type text)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以使用python-docx库来生成多级目录及标题和内容。首先需要安装python-docx库,可以使用以下命令进行安装: ``` pip install python-docx ``` 接下来,可以使用以下代码来生成多级目录和内容: ```python from docx import Document from docx.enum.text import WD_ALIGN_PARAGRAPH from docx.shared import Pt from docx.oxml.ns import qn def add_heading(paragraph, text, level): """ 添加标题 """ if level == 1: paragraph.add_run(text).bold = True paragraph.alignment = WD_ALIGN_PARAGRAPH.CENTER paragraph.paragraph_format.space_before = Pt(0) paragraph.paragraph_format.space_after = Pt(12) paragraph.style.font.size = Pt(20) paragraph.style.font.name = '黑体' elif level == 2: paragraph.add_run(text).bold = True paragraph.paragraph_format.space_before = Pt(12) paragraph.paragraph_format.space_after = Pt(6) paragraph.style.font.size = Pt(16) paragraph.style.font.name = '黑体' elif level == 3: paragraph.add_run(text).bold = True paragraph.paragraph_format.space_before = Pt(6) paragraph.paragraph_format.space_after = Pt(6) paragraph.style.font.size = Pt(14) paragraph.style.font.name = '黑体' def add_content(paragraph, text): """ 添加内容 """ paragraph.add_run(text) paragraph.paragraph_format.space_before = Pt(6) paragraph.paragraph_format.space_after = Pt(6) paragraph.style.font.size = Pt(12) paragraph.style.font.name = '宋体' def add_toc(document): """ 添加目录 """ paragraph = document.add_paragraph() paragraph.add_run('目录').bold = True paragraph.alignment = WD_ALIGN_PARAGRAPH.CENTER paragraph.paragraph_format.space_before = Pt(0) paragraph.paragraph_format.space_after = Pt(12) paragraph.style.font.size = Pt(20) paragraph.style.font.name = '黑体' toc = document.add_paragraph() toc.style.font.name = '宋体' toc.style.font.size = Pt(12) toc.alignment = WD_ALIGN_PARAGRAPH.CENTER for i in range(3): toc.add_run('\t' * i + ' ') toc.add_run('第%d章 ' % (i+1)) toc.add_run('章节标题') toc.add_run('\t') toc.add_run(str(document.page_number-1)) toc.add_run('\n') if __name__ == '__main__': document = Document() # 添加目录 add_toc(document) # 添加内容 for i in range(3): heading1 = document.add_paragraph() add_heading(heading1, '第%d章 章节标题' % (i+1), 1) for j in range(2): heading2 = document.add_paragraph() add_heading(heading2, '第%d节 章节标题' % (j+1), 2) for k in range(3): content = document.add_paragraph() add_content(content, '第%d小节 内容' % (k+1)) document.save('test.docx') ``` 这段代码会生成一个包含三个章节,每个章节包含两个小节,每个小节包含三个小节内容的文档,并且会自动生成目录。其中,`add_heading`函数用于添加标题,`add_content`函数用于添加内容,`add_toc`函数用于添加目录。在添加标题和内容时,可以根据不同级别设置不同的样式。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值