加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

regex – 用于从MDX查询中提取元素的正则表达式

发布时间:2020-12-14 02:29:21 所属栏目:百科 来源:网络整理
导读:我想从给定的MDX查询中提取信息或查询轴元素. 假设我有这个查询: SELECT NON EMPTY { Hierarchize({[Product].[Product Family].Members})} ON COLUMNS,NON EMPTY Hierarchize ( Union ( CrossJoin ( {[Time].[1997].[Q1]},CrossJoin ([Store].[Store Name]
我想从给定的MDX查询中提取信息或查询轴元素.
假设我有这个查询:
SELECT NON EMPTY {
    Hierarchize({[Product].[Product Family].Members})
} ON COLUMNS,NON EMPTY Hierarchize ( 
    Union ( 
        CrossJoin ( {[Time].[1997].[Q1]},CrossJoin ([Store].[Store Name].Members,[Store Type].[Store Type].Members
            )
        ),CrossJoin({[Time].[1997].[Q2]},CrossJoin([Store].[Store Name].Members,[Store Type].[Store Type].Members
            )
        )
    )
) ON ROWS FROM [Sales] 
WHERE {
    Hierarchize({[Measures].[Unit Sales]})
}

我想提取的子字符串有这样的模式:
[…](.[…]) 要么
[…].[…]员

请注意,…表示任何字母数字,并且括号内的含义可以重现.
因此,我期望的结果是:

[Product].[Product Family].Members; [Time].[1997].[Q1];
[Time].[1997].[Q2]; [Store].[Store Name].Members; [Store Type].[Store
Type].Members; [Measure].[Unit Sales]

我尽我所能,最后想出了这个正则表达式:

[.*?[A-Za-zs]](.*?(.[.*?[A-Za-zs]])|(.Members))

但结果是:

[Product].[Product Family]; [Time].[1997].[Q1]},CrossJoin ([Store];
[Store Name].Members,[Store Type].[Store Type]; [Time].[1997].[Q2]},
CrossJoin([Store]; [Store Name].Members,[Store Type].[Store Type];
[Sales] WHERE {Hierarchize({[Measures].[Unit Sales]

有人可以对我的正则表达式进行任何更正吗?
任何帮助,将不胜感激.

嗯,你能试试这个:
([[w ]+].[[w ]+](?:.(?:Members|[Qd]))?)

这似乎对我有用.我在Rubular试了一下.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读