ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

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

[求助] 正则求助: 类似SQL 语句的Select 部分拆解

[复制链接]

TA的精华主题

TA的得分主题

发表于 2024-3-18 01:52 | 显示全部楼层 |阅读模式
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助


正则求助: 类似SQL 语句的Select 部分拆解
所有文本内容 前后都是两个双引号

  1. StrSelect = "datediff(""D"",[日期],""2024-03-11"") AS [日期],"""" AS [代表],Mid([姓名],2,2) AS [NewName],[体重] AS [肥度],[班级]"
复制代码


用逗号隔开的内容, 但是括号内的不拆出来
希望得到的结果:  是5个内容
  1. datediff(""D"",[日期],""2024-03-11"") AS [日期]
  2. """" AS [代表]
  3. Mid([姓名],2,2) AS [NewName]
  4. [体重] AS [肥度]
  5. [班级]
复制代码


TA的精华主题

TA的得分主题

发表于 2024-3-18 08:10 | 显示全部楼层
(\w+\(.+?\)[^,]+)|[^,]+

评分

1

查看全部评分

TA的精华主题

TA的得分主题

发表于 2024-3-18 09:16 | 显示全部楼层

TA的精华主题

TA的得分主题

 楼主| 发表于 2024-3-18 11:11 | 显示全部楼层
limonet 发表于 2024-3-18 09:16
(?:^|,)(.*?AS )?\[.*?\](?=,|$)

在Excel中测试未通过  
网页工具也未通过 http://tool.openi.cn/regex/

2楼的没问题
能帮忙在看看么: 正则求助.rar (16.6 KB, 下载次数: 7)

正则好深奥啊, 上面2位的表达式完全看不懂啊
什么时候能有此功力呢!!?

TA的精华主题

TA的得分主题

发表于 2024-3-18 13:11 | 显示全部楼层
关键字:¥¥¥¥¥¥
GIF 2024-03-18 13-11-15.gif

工作簿1.zip

14.38 KB, 下载次数: 5

TA的精华主题

TA的得分主题

发表于 2024-3-18 13:12 | 显示全部楼层
Sub limonet()
    StrSelect = "datediff(""D"",[日期],""2024-03-11"") AS [日期],"""" AS [代表],Mid([姓名],2,2) AS [NewName],[体重] AS [肥度],[班级]"
    With CreateObject("vbscript.regexp")
        .Pattern = "(.*?AS \[.*?\])(,)"
        .Global = True
        Range("A1").Resize(1, 5) = Split(.Replace(StrSelect, "$1¥"), "¥")
    End With
End Sub

评分

3

查看全部评分

TA的精华主题

TA的得分主题

 楼主| 发表于 2024-3-18 21:46 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
limonet 发表于 2024-3-18 13:12
Sub limonet()
    StrSelect = "datediff(""D"",[日期],""2024-03-11"") AS [日期],"""" AS [代表],Mid([ ...

虽然看不懂  但是很好用!
十分感谢!!!

TA的精华主题

TA的得分主题

发表于 2024-3-18 21:51 | 显示全部楼层
opiona 发表于 2024-3-18 21:46
虽然看不懂  但是很好用!
十分感谢!!!

谦虚了,正则只是VBA很小的一块知识,对于您来说很简单了。

TA的精华主题

TA的得分主题

 楼主| 发表于 2024-3-19 20:14 | 显示全部楼层
本帖最后由 opiona 于 2024-3-19 20:17 编辑

再次求助    开头有: SUM,AVG,COUNT,MAX,MIN,FIRST,LAST

SUM(IIF([字段名E]='ABCD',[字段名F],0)+888)-MAX([字段名G])+35-8
拆解成:
          SUM(IIF([字段名E]='ABCD',[字段名F],0)+888)     再次拆解为:  SUM      IIF([字段名E]='ABCD',[字段名F],0)    888
          MAX([字段名G])                                                再次拆解为:  MAX     [字段名G]
          35
          8

TA的精华主题

TA的得分主题

发表于 2024-3-19 21:43 | 显示全部楼层
opiona 发表于 2024-3-19 20:14
再次求助    开头有: SUM,AVG,COUNT,MAX,MIN,FIRST,LAST

SUM(IIF([字段名E]='ABCD',[字段名F],0)+888)-M ...

\w+|\(.+?\)(?=\+)
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

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

GMT+8, 2024-11-18 01:49 , Processed in 0.034628 second(s), 12 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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