ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

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

[已解决] 将相关文字和数字进行截取

[复制链接]

TA的精华主题

TA的得分主题

发表于 2024-7-24 20:26 | 显示全部楼层 |阅读模式
本帖最后由 jonyzhao 于 2024-7-27 16:00 编辑

1.将品名中含有B、A、C、M、MN、W、E(第一个“-”前面的相关字母除外)
,且其之后为数字的那段文字截取下来。
2.将分类1中字母到”K“或”M“中间,或字母之后的数字截取下来,
如果分类1中不含有"K“,则将截取的数字除1000,如果含有"M",
则将截取的数字乘1000,其它的不变
3.分类3为数字前的字母及文字

公司电脑EXCEL版本为2016版,目前换不了高版本的EXCEL。

感谢高手相助。



555.png

工作簿1.rar

9.92 KB, 下载次数: 6

TA的精华主题

TA的得分主题

发表于 2024-7-24 20:53 | 显示全部楼层
本帖最后由 hxj119 于 2024-7-24 20:56 编辑

低版本,开火车:
B2=IF(ISNUMBER(--TRIM(LEFT(SUBSTITUTE(MID(A2,FIND("-",A2)+1,20),"-",REPT(" ",99)),99))),TRIM(MID(SUBSTITUTE(MID(A2,FIND("-",A2)+1,20),"-",REPT(" ",99)),99,99)),TRIM(LEFT(SUBSTITUTE(MID(A2,FIND("-",A2)+1,20),"-",REPT(" ",99)),99)))

69{WP`O}6A59GZOJR6ST}I9.png

评分

1

查看全部评分

TA的精华主题

TA的得分主题

发表于 2024-7-24 21:06 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
第15行和28行,0B1M  结果1000,A1M 结果1,为啥M的结果不一样?

TA的精华主题

TA的得分主题

发表于 2024-7-24 21:19 | 显示全部楼层

低版本,开火车:
=IFNA(-LOOKUP(1,-RIGHT(IF(OR(RIGHT(B2,1)="K",RIGHT(B2,1)="M"),REPLACE(B2,LEN(B2),1,""),B2),ROW(INDIRECT("$1:$"&LEN(IF(OR(RIGHT(B2,1)="K",RIGHT(B2,1)="M"),REPLACE(B2,LEN(B2),1,""),B2))))))/IF(OR(RIGHT(B2,1)="K",RIGHT(B2,1)="M"),1,1000),"未找到")


U]S$YSTD${IG@N%_B@6C4{3.png

TA的精华主题

TA的得分主题

 楼主| 发表于 2024-7-24 21:23 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
hxj119 发表于 2024-7-24 21:06
第15行和28行,0B1M  结果1000,A1M 结果1,为啥M的结果不一样?

写错了,也是1000

TA的精华主题

TA的得分主题

发表于 2024-7-24 21:35 | 显示全部楼层
本帖最后由 丢丢表格 于 2024-7-24 21:41 编辑

b2

=HLOOKUP("??*",TEXTSPLIT(TEXTAFTER(A2,"-"),"-"),1,)

c2
=-LOOKUP(1,-RIGHT(LEFT(B2,LEN(B2)-1),{1,2,3,4}))*LOOKUP(RIGHT(B2),{"0","K","M";"0.01",1,1000})



B2 (低版本)
=HLOOKUP("??*",TRIM(MID(SUBSTITUTE(A2,"-",REPT(" ",99)),{99,199},99)),1,)

评分

2

查看全部评分

TA的精华主题

TA的得分主题

 楼主| 发表于 2024-7-24 21:46 | 显示全部楼层
hxj119 发表于 2024-7-24 21:19
低版本,开火车:
=IFNA(-LOOKUP(1,-RIGHT(IF(OR(RIGHT(B2,1)="K",RIGHT(B2,1)="M"),REPLACE(B2,LEN(B2) ...

M没有乘1000,其它的都可以。
厉害了。

TA的精华主题

TA的得分主题

 楼主| 发表于 2024-7-24 21:48 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
丢丢表格 发表于 2024-7-24 21:35
b2

=HLOOKUP("??*",TEXTSPLIT(TEXTAFTER(A2,"-"),"-"),1,)

b2应该是高版本的公式,C2的可以。

简单明了,高手。

TA的精华主题

TA的得分主题

发表于 2024-7-24 21:58 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2024-7-24 22:02 | 显示全部楼层
本帖最后由 hxj119 于 2024-7-24 22:05 编辑

更新公式:
分类2:=IFNA(-LOOKUP(1,-RIGHT(IF(OR(RIGHT(B2,1)="K",RIGHT(B2,1)="M"),REPLACE(B2,LEN(B2),1,""),B2),ROW(INDIRECT("$1:$"&LEN(IF(OR(RIGHT(B2,1)="K",RIGHT(B2,1)="M"),REPLACE(B2,LEN(B2),1,""),B2))))))/IF(RIGHT(B2,1)="K",1,IF(RIGHT(B2,1)="M",10^-3,1000)),"未找到")

Z8N62{}6NRV108WW9XOA_{U.jpg

评分

1

查看全部评分

您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

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

GMT+8, 2024-9-21 17:44 , Processed in 0.047877 second(s), 14 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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