热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

如何在ExcelVBA中将字符串格式化为UUID?

如何解决《如何在ExcelVBA中将字符串格式化为UUID?》经验,为你挑选了1个好方法。

我有一个小VBA项目,但我有一个问题.

我需要一个32个字符的十六进制字符串并将其转换为UUID.

Input: b10a8db164e0754105b7a99be72e3fe5
Output: b10a8db1-64e0-7541-05b7-a99be72e3fe5

我不知道从哪里开始,但我想我需要在这么多字符之后拆分字符串然后重新组合它.有效地执行此操作的任何指针或方法?



1> Brad..:

您可以使用Left,Right并将Mid其转换为您想要的格式.

Function makeUuid(asString As String) As String
    Dim asUuidFormat As String
    If Len(asString) <> 32 Then
        makeUuid = asString
        Exit Function
    End If
    Dim firstPart As String, secondPart As String, thirdPart As String, fourthPart As String, fifthPart As String
    firstPart = Left(asString, 8)
    secOndPart= Mid(asString, 9, 4)
    thirdPart = Mid(asString, 13, 4)
    fourthPart = Mid(asString, 17, 4)
    fifthPart = Right(asString, 12)
    makeUuid = firstPart & "-" & secondPart & "-" & thirdPart & "-" & fourthPart & "-" & fifthPart
End Function

您可以在工作表中使用`= makeUuid(A4)'(或任何单元格)

在此输入图像描述

如果传入的不是32个长度的字符串,它不会进行格式化,只返回原始字符串.


推荐阅读
author-avatar
残念易_138
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有