首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >找到"abc",替换为"abc"+####

找到"abc",替换为"abc"+####
EN

Stack Overflow用户
提问于 2018-01-05 21:57:29
回答 3查看 63关注 0票数 0

我有一个包含"abc1234“、"abc2345”、"abc3456“等内容的数据集。

"abc“部分是常量和我找到它们的方法。

但当我找到它们时,我想替换/删除常量部分和变量部分的3个字符。

例如,Find "abc"-> = "abc1234“->将"abc123”替换为"“。

我试着用下面这样的东西来做。使用#作为每个变量位置/字符的通配符。但不起作用。

代码语言:javascript
复制
Selection.Replace what:="abc", Replacement:=""+###, _
LookAt:=xlPart, SearchOrder:=xlByColumns, MatchCase:=False, SearchFormat _
:=False, ReplaceFormat:=False

我做错了什么?

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2018-01-05 22:26:35

嗯,你必须把通配符放在搜索模式中,而不是替换模式中。此外,对于单个字符,通配符是?

代码语言:javascript
复制
Selection.Replace what:="abc???", Replacement:="", _
   LookAt:=xlPart, SearchOrder:=xlByColumns, MatchCase:=False, SearchFormat _
   :=False, ReplaceFormat:=False

'input   -> output
'abc1234 -> 4
'abc2345 -> 5
'abc3456 -> 6
票数 2
EN

Stack Overflow用户

发布于 2018-01-05 22:27:39

你有没有尝试过函数replace()?

Replace("abc1234","abcd123","")得到4

票数 0
EN

Stack Overflow用户

发布于 2018-01-05 22:32:01

另一种不需要搜索和替换的可能性:

代码语言:javascript
复制
Dim ra As Range
For Each ra In Selection
    If Left(ra.Value, 3) = "abc" Then
ra.Value = Mid(ra.Value, 7, 50)
    End If
Next

处理我的Excel

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/48115085

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档