首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >删除Trail逗号而不删除颜色格式

删除Trail逗号而不删除颜色格式
EN

Stack Overflow用户
提问于 2020-11-21 06:22:22
回答 1查看 58关注 0票数 1

我找到了这个vba,它修剪了后面的逗号,但是它改变了我的颜色格式。

可以保留颜色格式吗?

电流码

代码语言:javascript
复制
Function removetrailcomma(txt As String) As String
    If Right(txt, 1) = " " Or Right(txt, 1) = "," Then
        removetrailcomma = removetrailcomma(Left(txt, Len(txt) - 1))
    Else
        removetrailcomma = txt
    End If
End Function

当前单元格-Peter(黑色字体),第一级(红色字体),

当前代码结果-Peter(黑色字体),一级(黑色字体)

预期结果-Peter(黑色字体),一级(红色字体)

EN

回答 1

Stack Overflow用户

发布于 2020-11-22 02:29:52

问题是,您正在尝试编辑单元格,方法是取出文本,更改文本,然后将文本放回。您正在处理的文本不具有字符串的固有格式。文本的颜色是范围的属性(详见Font.Color性质 )。所以当你把字符串放回单元格时,你会擦除单元格的格式。

若要在不消除格式设置的情况下更改单元格中的文本,可以更容易地处理单元格本身的Range对象。这里有一个可以做你想做的事情的函数:

代码语言:javascript
复制
Sub CleanupCell(InputCell As Range)
    Dim DataLen As String, DeleteChar As String
    
    'Take in last character in cell
    DeleteChar = Right(InputCell.Value, 1)
    
    'Delete the last character in the cell if a comma or space
    If (DeleteChar = "," Or DeleteChar = " ") Then
        DataLen = Len(InputCell.Value)
        InputCell.Characters(DataLen, 1).Delete
    End If
End Sub

该函数不会消除格式设置,因为它不会覆盖单元格中的文本,只会从单元格的末尾删除一个字符。这是基于较旧的Sx答案的。

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

https://stackoverflow.com/questions/64940418

复制
相关文章

相似问题

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