Foxtable(狐表)用户栏目专家坐堂 → 如何以表中mm为标签,提取之前的标红部分数据


  共有2515人关注过本帖树形打印复制链接

主题:如何以表中mm为标签,提取之前的标红部分数据

帅哥哟,离线,有人找我吗?
lcr1996
  1楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:婴狐 帖子:7 积分:121 威望:0 精华:0 注册:2019/5/27 16:11:00
如何以表中mm为标签,提取之前的标红部分数据  发帖心情 Post By:2019/6/20 10:39:00 [只看该作者]

您好!请问如何用代码来提取表中标红部分,并将其设置为新的一列(数据变了也能提取)
图片点击可在新窗口打开查看此主题相关图片如下:捕获.png
图片点击可在新窗口打开查看

 回到顶部
帅哥哟,离线,有人找我吗?
有点甜
  2楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:版主 帖子:85326 积分:427815 威望:0 精华:5 注册:2012/10/18 22:13:00
  发帖心情 Post By:2019/6/20 10:40:00 [只看该作者]

参考

 

Dim str As String = "001 8889  4.045 mm     5920m/s"
Dim mc = System.Text.RegularExpressions.Regex.Matches(str, "[0-9.]+(?=.*?mm)")
msgbox(mc(mc.count-1).value)


 回到顶部
帅哥哟,离线,有人找我吗?
lcr1996
  3楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:婴狐 帖子:7 积分:121 威望:0 精华:0 注册:2019/5/27 16:11:00
  发帖心情 Post By:2019/6/20 18:04:00 [只看该作者]

您好!这个只能一次提取一行,能不能一次性提取一列的

 回到顶部
帅哥哟,离线,有人找我吗?
明天的灵
  4楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:小狐 帖子:399 积分:4833 威望:0 精华:0 注册:2017/2/7 7:41:00
  发帖心情 Post By:2019/6/20 18:15:00 [只看该作者]

关键是上面代码,多行的话,加循环

 回到顶部
帅哥哟,离线,有人找我吗?
lcr1996
  5楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:婴狐 帖子:7 积分:121 威望:0 精华:0 注册:2019/5/27 16:11:00
  发帖心情 Post By:2019/6/20 18:55:00 [只看该作者]

您好!这个要的是在数据更改了的情况下也能对表中NoName列的标红部分进行提取(格式一样,只改变标红部分)

 回到顶部
帅哥哟,离线,有人找我吗?
有点甜
  6楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:版主 帖子:85326 积分:427815 威望:0 精华:5 注册:2012/10/18 22:13:00
  发帖心情 Post By:2019/6/20 21:53:00 [只看该作者]

For Each r As Row In Tables("表A")
    Dim str As String = r("第一列")
    Dim mc = System.Text.RegularExpressions.Regex.Matches(str, "[0-9.]+(?=.*?mm)")
    r("第二列") = mc(mc.count-1).value
Next

 回到顶部
帅哥哟,离线,有人找我吗?
lcr1996
  7楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:婴狐 帖子:7 积分:121 威望:0 精华:0 注册:2019/5/27 16:11:00
  发帖心情 Post By:2019/6/21 14:30:00 [只看该作者]

谢谢您!那怎样将最前面编号(标红部分)提取出来?
图片点击可在新窗口打开查看此主题相关图片如下:1.png
图片点击可在新窗口打开查看
[此贴子已经被作者于2019/6/21 14:33:38编辑过]

 回到顶部
帅哥哟,离线,有人找我吗?
有点甜
  8楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:版主 帖子:85326 积分:427815 威望:0 精华:5 注册:2012/10/18 22:13:00
  发帖心情 Post By:2019/6/21 14:42:00 [只看该作者]

 

For Each r As Row In Tables("表A")
    Dim str As String = r("第一列")
    Dim mc = System.Text.RegularExpressions.Regex.Matches(str, "[0-9.]+(?=.*?mm)")
    r("第二列") = mc(mc.count-2).value
Next

 

 


 回到顶部