ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

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

[已解决] 关于用M语言实现Indirect功能的探讨

[复制链接]

TA的精华主题

TA的得分主题

发表于 2021-1-6 14:59 | 显示全部楼层 |阅读模式
本帖最后由 gavin.w 于 2021-1-6 22:37 编辑

假设已存在查询“表1”,新建一个空白查询并在编辑栏输入公式 "= 表1",则新查询返回"表1"。

类似于Excel的Indirect函数,是否有可能动态返回已存在的表,即通过公式 "=Indirect("表"&"X")",根据X的动态取值返回"表1"、"表2"..."表X"?

请各位大佬指点。

谢谢。

TA的精华主题

TA的得分主题

发表于 2021-1-6 15:20 | 显示全部楼层

TA的精华主题

TA的得分主题

 楼主| 发表于 2021-1-6 22:02 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
本帖最后由 gavin.w 于 2021-1-6 22:35 编辑

感谢大佬拨冗指点。

谢谢。
PS:
1、Record.FieldOrDefault(record as nullable record, field as text, optional defaultValue as any) as any
返回记录 record 中指定字段 field 的值。 如果找不到字段,则返回可选的 defaultValue。
2、#shared 调取Power Query M函数集。
3、查询选项 -->隐私级别-->使用您的组合数据时的隐私级别设置。




TA的精华主题

TA的得分主题

发表于 2021-1-7 05:30 | 显示全部楼层
本帖最后由 ThxAlot 于 2021-1-7 11:28 编辑

M里有个和INDIRCT很神似的函数
  1. = Expression.Evaluate("Query1", #shared)
复制代码
或者
  1. = Expression.Evaluate("Query1", [Query1=Query1])
复制代码


比较特别的是,Expression.Evaluate(arg1 as text, optional arg2 as record)中arg1的计算是在arg2所定义的估值环境中进行的。

光这样说太抽象,这是一篇参考文章,有兴趣的话可以了解了解:
https://blog.crossjoin.co.uk/2015/02/06/expression-evaluate-in-power-querym/

评分

1

查看全部评分

TA的精华主题

TA的得分主题

 楼主| 发表于 2021-1-7 16:25 | 显示全部楼层
本帖最后由 gavin.w 于 2021-1-7 16:32 编辑
ThxAlot 发表于 2021-1-7 05:30
M里有个和INDIRCT很神似的函数
或者

感谢指点,两种写法,结果相同。

但操作中,PQ能完美返回,加载到模型时就会报错(即便只有一列一行),提示如下:

“OLE DB 或 ODBC 错误 : [Expression.Error] 无法将值 null 转换为类型 Table。。”

或许是表太多的缘故,可惜了,本想可以动态选择不同场景下的源表。
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

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

GMT+8, 2024-11-15 16:22 , Processed in 0.035850 second(s), 17 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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