日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

【Excel VBA】Len的有趣之处——获取的长度怎么不一致?

發布時間:2024/1/8 编程问答 55 豆豆
生活随笔 收集整理的這篇文章主要介紹了 【Excel VBA】Len的有趣之处——获取的长度怎么不一致? 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

綱舉目張

  • 說明
  • 代碼code
  • 使用說明

說明

在Excel的單元格中輸入函數=LEN(“abc”)結果為3;輸入函數=LEN(“啊bc”)結果也是3,看似沒有問題但是實際上LEN的兩個參數實際占用的長度可是不一樣的,見下圖:

“啊bc”就是比“abc”長1個字符。原因是LEN函數計算的是字符的個數,雖然1個漢字占據了兩個英文字母的長度,但是也是1個字符。
如果在實際的應用中我們要考慮的是字符串占據的長度該如何呢?那么就有請LENB函數:輸入函數=LENB(“abc”)結果為3;輸入函數=LENB(“啊bc”)結果為4。
今天的文章就這么結束了?并沒有,我們還有一個問題要繼續探討,如果在VBA中使用這兩個函數會是什么樣的結果呢?先寫代碼如下:

Sub 有趣的LEN()Cells(3, 4).Value = Len(Cells(3, 1).Value)Cells(4, 4).Value = Len(Cells(4, 1).Value)Cells(3, 5).Value = LenB(Cells(3, 1).Value)Cells(4, 5).Value = LenB(Cells(4, 1).Value) End Sub

運行代碼后,效果如下:

可以看到在LEN函數在Excel單元格函數與VBA函數得到的結果是一致的,但是LENB函數就出現了不同,這就表明在Excel單元格函數中LENB將英文及數字認為只占用了1個字符,漢字占用了2個字符;在VBA函數中LENB將英文及數字與漢字一視同仁均視為占用了2個字符。
如果我們想要在VBA函數中達到Excel單元格函數的LENB的效果該怎么編寫代碼呢?各位看官,代碼來了!

代碼code

Sub 有趣的LEN()Cells(3, 4).Value = Len(Cells(3, 1).Value)Cells(4, 4).Value = Len(Cells(4, 1).Value)Cells(3, 5).Value = LenB(Cells(3, 1).Value)Cells(4, 5).Value = LenB(Cells(4, 1).Value)Cells(3, 6).Value = LenC(Cells(3, 1).Value)Cells(4, 6).Value = LenC(Cells(4, 1).Value) End Sub'字符長度,因為中文和英文所占字符長度不同,故另寫函數獲取 Public Function LenC(strContent As String) As IntegerDim intC As IntegerLenC = 0For intC = 1 To Len(strContent)If AscW(Mid(strContent, intC, 1)) > 256 Or AscW(Mid(strContent, intC, 1)) < 0 ThenLenC = LenC + 2ElseLenC = LenC + 1End IfNext End Function

使用說明

通過自己編寫一個名為LenC的函數,逐個判斷字符串的每一個字符是什么類別的,從而計算字符串的占位長度。本例整體運行效果如下圖:

如有意見建議或使用中出現Bugq請留言,謝謝!

總結

以上是生活随笔為你收集整理的【Excel VBA】Len的有趣之处——获取的长度怎么不一致?的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。