ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

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

[求助] 提取文字中的多个数字

[复制链接]

TA的精华主题

TA的得分主题

发表于 2018-4-27 14:38 | 显示全部楼层 |阅读模式
麻烦各位高手帮忙解决下,多谢了!

12.JPG

数字提取.zip

7.9 KB, 下载次数: 25

TA的精华主题

TA的得分主题

发表于 2018-4-27 15:48 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
  1. =IFERROR(LOOKUP(9,--RIGHT(TRIM(MID(SUBSTITUTE($B4,",",REPT(" ",99)),FIND(LEFT(M$3,2),SUBSTITUTE($B4,",",REPT(" ",99))),99)),{1,2,3})),"")
复制代码

质保也可以弄的,但是公式太长,没有意义,质保期手动弄吧,不通用,简直不通用,仅供参考。

TA的精华主题

TA的得分主题

发表于 2018-4-27 15:49 | 显示全部楼层
  1. =IFERROR(LOOKUP(9,--RIGHT(TRIM(MID(SUBSTITUTE($B4,",",REPT(" ",99)),FIND(LEFT(M$3,2),SUBSTITUTE($B4,",",REPT(" ",99))),99)),{1,2,3})),"")
复制代码
仅供参考,不通用。

TA的精华主题

TA的得分主题

 楼主| 发表于 2018-4-27 16:24 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
laowuwyx 发表于 2018-4-27 15:49
仅供参考,不通用。

谢谢,但是这个公式有的能计算,质保比率计算不出,质保期算不出,还有一些计算是错误的

TA的精华主题

TA的得分主题

发表于 2018-4-27 16:26 | 显示全部楼层
kenny0918 发表于 2018-4-27 16:24
谢谢,但是这个公式有的能计算,质保比率计算不出,质保期算不出,还有一些计算是错误的

说过是参考的,不通用,主要是数据找不到规律。

TA的精华主题

TA的得分主题

发表于 2018-4-27 16:29 | 显示全部楼层
  1. 将"质保款"改成"质保期款"
  2. Function aa(rng As Range, rng1 As Range)
  3. Dim ar, i%, d As Object, s
  4. Set d = CreateObject("vbscript.regexp")
  5. With d
  6.     .Global = True
  7.     .Pattern = "[^\d+]"
  8. End With
  9. ar = Split(rng.Value, ",")
  10. For i = 0 To UBound(ar)
  11.     If ar(i) Like "*" & Replace(rng1.Value, "款", "") & "*" Then
  12.         s = d.Replace(ar(i), "") & "%"
  13.     ElseIf rng1.Value = "质保期(天)" Then
  14.         If ar(i) Like "*年*" Then
  15.             s = InStr("一二三四五六七八九", Split(Replace(ar(i), "质保", ""), "年")(0)) * 365
  16.         ElseIf ar(i) Like "*月*" Then
  17.             s = d.Replace(ar(i), "") * 30
  18.         End If
  19.     End If
  20. Next
  21. aa = s
  22. If s = "" Then aa = ""
  23. Set d = Nothing
  24. End Function
复制代码

TA的精华主题

TA的得分主题

发表于 2018-4-27 16:30 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2018-4-27 16:31 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2018-4-27 17:18 | 显示全部楼层
QQ截图20180427171800.jpg

数字提取a.zip

12.9 KB, 下载次数: 30

TA的精华主题

TA的得分主题

发表于 2018-4-27 17:36 | 显示全部楼层
  1. =IFERROR(MID($B4,FIND(LEFT(N$3,2),$B4)-1+FIND("%",MID($B4,FIND(LEFT(N$3,2),$B4),15))-2,3),"")
复制代码
第一个公式把文字改成函数,公式可以右拉,不至于每列都写一个公式。
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

关闭

最新热点上一条 /1 下一条

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

GMT+8, 2024-4-20 01:00 , Processed in 0.050046 second(s), 12 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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