⑴ power query插件应用案例(二)
对于数据分析,工作簿或工作表合并是我们经常遇到的问题,但不同的数据结构往往有不同的应对方式。合适的处理方式,也唯有如此,才能带来理想效果。例如下图中,要将数十个分公司的数据汇总到同一张表内,再利用Power BI建立可视化动态图表。仅单纯地手工复哗帆制粘贴不仅显得效率低下,还容易造成数据缺失,但借助power query插件则能轻易取得数十份工作簿的所有数据,并且还可实现数据的自动更新。
Step1:打开汇总工作表,点开Power query选项卡,选择数据来源,[从文件]→[从文件夹],将保存数据的文件夹直接导入power query查询编辑器。
Step2:在[选择数据源]内找到该文件夹,单击“编辑”按钮,进入“查询编辑器”,其操作界面如下图所示:
Step3:点击“开始”选项卡,选中“content”列,在“删除列”中将其他所有列删掉,仅保留该列。
Step4:点开“添加列”选项卡,选择“自定义列”,在弹出的“添加自定义列”对话框内新建新列名称及自定义列公式:[=Excel.Workbook([content],true)]。其中,函数Excel.Workbook每个单词首字母必须大写,答芦梁参数[content]是双击或插入“可用列”来完成的。最终效果可见下图。
Step5:点击“清单”列的扩展按钮,不勾选“使用原始列名作为前缀”,再点击“清运确定”。
Step6:继续选中“Data”列,通过“删除其他列”将多余的列去掉,再次点击该列右上角的扩展按钮,将数据完全扩展开来。此时,将得到文件夹内所有工作簿汇总的数据。最后,在“开始”选项卡内点击“关闭并上载至”将数据添加到数据模型内,通过powerpivot插件做进一步地处理。
⑵ Power Query加载链接并刷新的疑惑
最近在学习Power Query,遇到一个应该是很简单,但我不知道到底问题是出在哪里的问题;具体翻车现场回顾:
是这样,我有一个工作表(查询表1),如下:
现在在另外一个工作簿中,有另一个我御枝需镇裂敏要查询引用的表(查询表2),如下:
我想从查询表里面把查询表2里面的金额引用过来,但是我想只引用链接就行,不想将表加载过来,具体我是这么操作的:
1、选择查询表1的数据菜单,选择自表格/区域,建立查询:
之后,关闭并上载到工作表。
2、再新建一个查询,将查询2引入查询表1,并选择仅创建连接:
目前有两个查询,查询表1和查询表2,并且查询表2仅限链接:
3、合并查询:
打开查询表1,进入Power query,选择合并查询:
合并两个工作表:
合并后如下:
展开查询表2:
查询完成,选择关闭并上载。返回工作表,结果如下:
修改/增加查询表2中的数据,返回到查询表1里面,进行刷新,问题来了:
无法刷新。。。。。
然后我试着把查询表加载到当前工作簿:
再刷新就没有问题了。。源世。。
但是这并不是我想要的结果,我就想只要链接,我不想加载很多表到现在这个工作表里面啊,希望看到的老师给我一个解答,康桑思密达~
谢谢qq群里的各位大神,问题已解决,下面是录制视频:
但链接确实还是不能刷新,可能我操作上还有问题,看到的大神麻烦告知,🙏
⑶ 2013excelpowerquery怎么上载至数据透视表
需要使用excel的powerquery插件,可扒耐以颂滑通过以下步骤来完成。
1、在Excel中点击文件,然后点击选项。
2、在选项对话框中点击高级,然后在保存选项卡中勾选在打开工作簿时启动PowerQuery。
3、然后打开你的数据文件,可以通过数据标签中的新建查询来打开PowerQuery窗口。
4、在PowerQuery窗口中选择需要上载到数据透视表的数据,然后点击关野此腊闭并应用。
5、最后,在数据标签中可以看到数据透视表选项,点击即可创建一个新的数据透视表,将PowerQuery上传的数据加载入该表中。
⑷ powerquery上载数据失败
powerquery上载数据失败是网络卡顿的原因,建议重启网络。
网络是由若干节点和连接这些节点的链路构成,表示诸多对象及其相互联系。
在1999年之前,人们一般认为网络的结构都是随机的。但随着Barabasi和Watts在1999年分别发现了网络的无标度和小世界特性并分别在世界着名的《科学》和《自然》杂志上发表了他们的发现之后,人们才认识到网络的复杂性。
网络会借助文字阅读、图片查看、影音播放、下载传输迹启、游戏、聊天等软件工具从文字、图片、声音、视频等方面给人们带来极其丰富的生活和美好的享受。
汉语中,“网络”一词最早用于电学《现代汉语词典》(1993年版)做出这样的解释:“在电的系统中,由若干元件组成的用来使电信号按一定要求传输的电路或这种电腔州唯路的部分,叫网络。”
在数学上,网络是一种图,一般认为专指加权图。网络除了数学定义外,还有具体的物理含义,即网络是从某种相同类型的实际问题中抽象出来的模型。在计算机领域中,网络是伍培信息传输、接收、共享的虚拟平台,通过它把各个点、面、体的信息联系到一起,从而实现这些资源的共享。网络是人类发展史来最重要的发明,提高了科技和人类社会的发展。
⑸ 如何在Power Query中提取数据——记录篇
表名为数据,第一步骤名称为源
(一)提取字段数:
Record.FieldCount (record as record ) as 搭卜 number
返回的是一个数字格式。
例:
直接使用:
Record.FieldCount([姓名="张三",成绩=100,学科="数学"])=3
在本询中使用:
Record.FieldCount(源{0})=3
在其他查询中使用:
Record.FieldCount(数据{0})=3
(二)提取字段名称列表
Record.FieldNames (record as record ) as list
返回的是字段名列表,如果返回的是list,请注意函数结尾正常来说会是复数,带s。
例:
直接使用
Record.FieldNames([姓名="张三",成绩=100,学科="数学"])={姓名","成绩","学科做亏"}
在本查询中使用
Record.FieldNames(源{0})={姓名","成绩","学科"}
在其他查询中使用
Record.FieldNames(数据{0})={姓名","成绩","学科"}
(三)提取记录值列表
Record.FieldValues (record as record ) as list
返回的是记录的值列表
例:
直接使用:
Record.FieldValues ([姓名="张三",成绩=100,学科="数学"])={"张三",100,"数学"}
在本查询中使用
Record.FieldValues (源{0})={"张三纯枝神",100, "数学"}
在其他查询中使用
Record.FieldValues (数据{0})={"张三",100, "数学"}
⑹ Excel Power Query:如何打开未加载的查询
——续上篇( Excel Power Query:工作簿数据的导入与整合 )——
首先,我们需要打开上篇创建的查询。由于该查询没有进行加载,而是仅创建了连接,所以较为隐蔽,不熟悉的人根本都不知道工作簿中创建了查询。具体操作如下:
打开未加载查询的纳颤方法1: 打开上篇保存的Excel文件《Excel建模分析》,依次点击:数据-获取数据-启动Power Query编辑器,如下图。进入Power Query编辑器后,点击左边导航窗格中的查询即可闷唤。
打开未加载查询的方法2: 依次点击数据-查询和连接,在右边出现的“查询&连接”窗格中,双击我们上篇所创建的查询“车缝生产过程记录”,即可打开。
这样,我们上次创建的查询“车缝生产过程记录”就打开了。在查询编辑器右边的“查询设置”窗格中,可以看到创建查询的每一个步骤。需要时,可以对这些步骤进行修改。
查询重命名: 我们也可以对查询进行重命名。可以在右边“查询设置”名称下洞罩败方的方框中修改,也可以直接双击左边查询导航窗格中的查询名称修改,还可以在左边查询导航窗格中的查询名称处点击鼠标右键并选择“重命名”来修改。我们将查询名称改为“Worksheet筛选”,如下图所示。
注意:如果查询已经添加到数据模型,则尽量不要再修改查询名称,否则数据模型会无法识别重命名后的查询,需要重新加载重命名后的查询,并需要对数据模型及其度量值重新进行设置。
下面又到要关闭Power Query编辑器的时候了。由于之前已经对查询的上载进行过设置,如果这次的设置跟上次一样,则只需要直接点击开始-关闭并上载即可。
未完待续……
⑺ excel如何从指定网站自动获取数据,并实时更新
powerquery可以,我看到有人用vba也实现了。
就我自己使用powerquery爬网站内容体验而言,数据很少,没啥反爬措施的,可以用用;如果要爬取的数据很多,有反爬措施,那么用powerquery就有点坑爹。
股票网站应该都有提供api?用powerquery调用api应该很好获取数据。
至于您说的选取股票名称,这些用powerquery倒是很好办。
⑻ EXCEL加载数据到PowerQuery时,可以选择是否在E
可以。
可以选择的,打开Excel2016预览版,导航到数据选项卡,会发现多了一个PowerQuery组,其中有新建查询下拉菜单,另外还有联机查询、显示查询、最近的源三个按老猜钮。
浏览一下新建查询下核轮拉菜单。单击新建查询下拉箭头,可以看到菜单中有从表格、侍氏型从文件、从数据库、从Azure、从其他源、合并查询等功能,有的还有二级菜单提供更详细的命令选择,可见支持的查询源非常多。
⑼ PowerQuery
查询设置位置
加入新文件
查询编辑器里无法直接更改数据,需要在上面的功能区里更改数据
合并文件: 合并查询(横向合并),追加查询(纵向合并)
选择多个表格 :按shift
如果报错大局,第一个查数据类型是否错误
修整和橡悔清除
拆分列
合并列
替换
判断奇偶数
删除规则: 默认保留第一行
排序和删除重复项同时使用会有冲突,解决办法: 转换---检测数据类型(排序后的箭头要消失)
保留重复项同理
先改数据类型制造错误,然后直接删除错误
行列互换
二维转一维,找二维表中以行的形式出现的字段,把这些字段进行逆透视(一维表:一个指标只有一个列;二维表:同个指标很多列)
一维转二维,找一维表中以列的形式出现的字段,把这些字段进行透视
数字排序按照,1,10,11,12,~19,2,20,21......的顺序,用怕排序更改
值为文本时,选择不要聚合
基本
第一行内容是选择分组条件
新列名:新建的列命名 操作:进滚如让行各种操作 柱:进行操作的列
高级
可以添加多个选择分组的条件
所有行
展开:打开选中列的信息 聚合:对选中列进行计数和求和
条件列:创建一个按条件添加当前所选列中的值的新列
索引列:创建一个新的列,其索引从0,1,或者自定义的数开始
重复列:创建一个新的列,复制当前所选列的值
自定义列(所有公式内的标点符号的都用英文输入法)
条件列文本:公式:“文本”
数值运算:公式:插入一个可用列+,-,*,/插入一个可用列
条件列:公式:
怎么将仅创建连接的数据导入工作表:查询和链接找到查询,然后右键点击加载到
若列名顺序不同,则合并时列名自动按照当前表格的列名顺序排序
若列名不同,则合并后自动生成空格
求每个区域内产品分类的金额
求每个区域每个产品的折扣金额
左外部:A,B,C,D,E; D,E
右外部:D,E; D,E,F,G
完全外部:A,B,C,D,E; D,E,F,G
内部:D,E; D,E
左反:A,B,C;
右反: ;F,G
⑽ 如何在Power Query中提取数据——列表篇(4)
(六)删除指定数据进行提取
1. 删除指定数据进行提取
List.RemoveRange (list as list , index as number , optional count as number ) as list
第1参数为数据列表;第2参数为索引数字格式,从0开始;第3参数为删除的数量,默认为1,如果为0则代表不删除,同时(第2参数+第3参数)<=列表值的数量;最终生成的是列表
例:
List.RemoveRange({1..10},0)={2..10}
List.RemoveRange({1..10},3,5)={1..3,9,10}
解释:第2参数索引3代表是第4位,也就是数值4,从此位置开始连续删除之后的5个值(也就是4-8)。
2. 删除空值后进行提取
List.RemoveNulls (list as list ) as list
对于列表中的空值进行删除,生成一个新的列表,只有1个参数。也可以理解为对一个列表选择不等于空值。List.Select(列表, each _<>null)
例:
List.RemoveNulls({null,1,2})={1,2}
List.Select({null,1,2},each _<>null)={1,2}
3. 批量删除匹配值后提取
List.RemoveMatchingItems (list1 as list , list2 as list , optional equationCriteria as any ) as list
从列表1从删除列表2的指定值,如果没找到则返回原始list1。第1参数为原始列表;第2参数为要删除的值列表;第三参数是可以指定一个可选相等条件来空值的测试。
例:
List.RemoveMatchingItems({1..10},{5..10})={1..4}
List.RemoveMatchingItems({#date(2018,11,11),1..10,"a".."友孙z"},List.Transform({0..364},(x)=>Date.AddDays(#date(2018,1,1),x)))={1..10,"a".."z"}
解释,通过List.Transform函数生成一个2018年的时间列表,这样就可以把原来列表中有关2018年的时间都可以去除。
List.RemoveMatchingItems({1..10},{5}, each_=5)={1..4,6..10}
解释:因为第3参数是=5,则找到等于5的值,并删除
List.RemoveMatchingItems({1..10},{5}, each_<=5)={6..10}
解释:因为第2参数为{5},第3参数为<=5,用第2参数和第3参数做比较,如果第2参数符合第3参数条件,则删除条件即为第3参数;如果第2参数不符合第3参数条件,则返回第3参数的相反值。
List.RemoveMatchingItems({1..10},{4}, each_>5)={5..10}
解释:因为第2参数不符合第3参数的条件,返回的结果是第三
List.RemoveMatchingItems({"a".."z"},{"b"},each_ >="a")={}
解释:因为第2参数符合第3参数,所以删除条件为第3参数,好岁链所有的值都大于"a",所以都被删除,返回的是一个空列表。
4. 从尾删雀拆除列表的最后几个数据
List.RemoveLastN (list as list , optional countOrCondition as any ) as any
从列表尾删除N个元素。第1参数是数据列表;第2参数可以是个数也可以是条件,如果是数字则直接删除最后N项的数据,如果是条件,一旦不满足条件即结束。
例:
List.RemoveLastN({1..10}, 3)={1..7}
List.RemoveLastN({1..10}, each _>5)={1..5}
解释:因为从后开始和5比,直到5为止结束。所以返回的是1-5的列表。
List.RemoveLastN({1..10,1}, each _>5)={1..10,1}
解释:因为从后开始,第一个是1,和第2参数的条件比较,是不符合的,所以就结束对比,也就是没有符合删除的条件,返回的就是原列表{1..10,1}。
5. 从头删除列表的最后几个数据
List.RemoveFirstN (list as list , optional countOrCondition as any ) as any
从列表头删除N个元素。第1参数是数据列表;第2参数可以是个数也可以是条件,如果是数字则直接删除最初的N项数据,如果是条件,一旦不满足条件即结束。
例:
List.RemoveFirstN({1..10},3)={4..10}
List.RemoveFirstN({1..10}, each _<5)={5..10}
解释:因为从头开始和小于5比,直到5为止结束。所以返回的是5-10的列表。
List.RemoveFirstN({10,1..10}, each _<5)={10,1..10}
解释:因为从后开始,第一个是10,和第2参数的条件比较,是不符合的,所以就结束对比,也就是没有符合删除的条件,返回的就是原列表{10,1..10}。
6. 根据新列表删除旧列表中的值
List.RemoveItems (list1 as list , list2 as list ) as list
第1个参数是需要被替换的列表;第2个参数是去要删除的值列表;返回生成的是新列表格式。
例:
List.RemoveItems({1..10},{5..10})={1..4}
List.RemoveItems({1,2,3,2,1},{1,2})={3}
List.RemoveItems({"a","b","c",1,2,3,"一","二"},{"a".."z"})={1..3,"一","二"}
解释:因为第2参数是英文字母的列表,所以把第1参数旧列表中所有英文26个字母单字都删除了。
问:那如何删除列表中值包含"a"的所有元素?
List.RemoveItems({"ab","bc"},List.FindText({"ab","bc"},"a"))={"bc"}
解释:因为要考虑到包含,可以参考4List.FindText函数,找到哪些包含"a"的列表值并生成一个新的需要删除的列表,最后通过List.RemoveItems函数来进行删除。