Excel中运行VB的函数

"插入" -》 "模块"

vbscript 复制代码
Function FormatCodeFlex(inputStr As String, Optional defaultVal As String = "0") As String
    On Error GoTo ErrorHandler
    Dim parts() As String
    Dim i As Integer
    
    ' 使用 "-" 分割字符串
    parts = Split(inputStr, "-")
    
    ' 确保至少有3个部分,不足的用默认值填充
    ReDim Preserve parts(2)
    For i = 0 To 2
        If parts(i) = "" Then parts(i) = defaultVal
    Next i
    
    ' 格式化每个部分
    FormatCodeFlex = Format(parts(0), "00") & "-" & _
                    Format(parts(1), "000") & "-" & _
                    Format(parts(2), "000")
    
    Exit Function
    
ErrorHandler:
    FormatCodeFlex = "输入无效!"
End Function

可能需要编译一下。 不记得了

调用

记录一下备忘。

写一个 excel中的vba函数, 判断 01-000-000 中的最后三位如果是 000 就返回0,如果不是000,就替换为000,并且返回整个字符串。

Function ProcessBOMCode(inputStr As String) As String

On Error GoTo ErrorHandler

Dim parts() As String

Dim lastPart As String

' 检查输入是否为空

If Trim(inputStr) = "" Then

ProcessBOMCode = "输入为空"

Exit Function

End If

' 使用 "-" 分割字符串

parts = Split(inputStr, "-")

' 检查是否有足够的部分

If UBound(parts) < 2 Then

ProcessBOMCode = "格式错误,需要xx-xxx-xxx格式"

Exit Function

End If

' 获取最后三位

lastPart = parts(2)

' 判断最后三位是否为"000"

If lastPart = "000" Then

ProcessBOMCode = 0 ' 返回数字0

Else

' 替换最后三位为"000",并返回整个字符串

parts(2) = "000"

ProcessBOMCode = parts(0) & "-" & parts(1) & "-" & parts(2)

End If

Exit Function

ErrorHandler:

ProcessBOMCode = "处理错误"

End Function

写一个excel的vba 处理 1 1-1 1-1-1 1-1-2 1-2 这样的不定长数据,去掉最后的一个数据。

Function RemoveLastPart(inputStr As String) As String

On Error GoTo ErrorHandler

Dim parts() As String

Dim result As String

Dim i As Integer

' 检查输入是否为空

If Trim(inputStr) = "" Then

RemoveLastPart = ""

Exit Function

End If

' 使用 "-" 分割字符串

parts = Split(inputStr, "-")

' 如果只有一个部分,直接返回空字符串

If UBound(parts) = 0 Then

RemoveLastPart = ""

Exit Function

End If

' 重新组合除最后一部分之外的所有部分

For i = 0 To UBound(parts) - 1

If i > 0 Then result = result & "-"

result = result & parts(i)

Next i

RemoveLastPart = result

Exit Function

ErrorHandler:

RemoveLastPart = "处理错误"

End Function

Deepseek真强。

相关推荐
ken223213 小时前
excel表格为什么越存文件越大? libreoffice 有效
excel
华大哥15 小时前
spring boot 和php 调用 LibreOffice 转换 Excel 到 PDF 完整实现
java·pdf·excel
Codiggerworld1 天前
Vim 实战:在 VS Code、JetBrains、终端里玩转 Vim
编辑器·vim·excel
开开心心_Every1 天前
多连接方式的屏幕共享工具推荐
运维·服务器·pdf·电脑·excel·tornado·dash
Jun6262 天前
QT(4)-EXCEL操作
开发语言·qt·excel
2501_907136823 天前
Excel文件强效安全修复工具-清理安全风险 可修复WPS编辑后Excel无法打开的文件
excel·wps
一位代码3 天前
Excel 文本连接符 & :基础用法与进阶技巧详解
excel
焱文8193 天前
wps excel指定数据区域,二维码生成区域,批量生成单元格二维码VBA宏代码
excel·wps
夏天里的肥宅水3 天前
EXCEL生成日历
excel
我命由我123453 天前
Excel - Excel 单元格格式同时设置日期时间
运维·学习·职场和发展·excel·求职招聘·职场发展·学习方法