萬盛學電腦網

 萬盛學電腦網 >> Excel教程 >> excel綜合 >> Excel單元格數據特殊處理實例

Excel單元格數據特殊處理實例

   有朋友要求Excel工作表的A1單元格和B1單元格中有兩個數字,這兩個數字有一部分相同,現在要找出其中相同的數字並寫入單元格C1,找出A1中有而B1中沒有的數字並寫入單元格D1,找出B1中有而A1中沒有的數字並寫入單元格E1。

  如下面的工作表圖片:

 

Excel單元格數據特殊處理實例 三聯

  我不知道給出的數字是否都是按這樣的規律,即第一個原始數據的後面幾位數與第二個原始數據的前面幾位數相同。如果是這個規律的話,則可以就這個具體的例子給出下面的代碼來實現:

  Sub SeparateNumber()

  Dim strFirst As String

  Dim strResult As String

  Dim StartNum As Integer

  Dim EndNum As String

  Dim i As Integer, j As Integer

  strFirst = Left(Range(”B1″), 1)

  StartNum = InStr(1, Range(”A1″), strFirst)

  j = 1

  For i = StartNum To Len(Range(”A1″))

  EndNum = Mid(Range(”A1″), i, 1)

  If EndNum = Left(Range(”B1″), j) Then

  j = j + 1

  End If

  Next i

  If j > 1 Then

  strResult = Mid(Range(”A1″), StartNum, i - 1)

  End If

  ‘單元格C1中的數據

  Range(”C1″).Value = strResult

  ‘單元格D1中的數據

  Range(”D1″).Value = Left(Range(”A1″), StartNum - 1)

  ‘單元格E1中的數據

  Range(”E1″).Value = Right(Range(”B1″), Len(Range(”B1″)) - j)

  End Sub

  代碼很簡單,只是運用了幾個VBA函數。

  討論:

  其實代碼可以進一步簡化,因為VBA還有一個數組函數(Split函數)。 如果要將其變為通用的,則可將上述代碼轉化為自定義函數,並用相對量代替代碼中的硬編碼。 兩個單元格中的數字如果不是按上面提到的規律,則可能兩個單元格中的數字中間部分相同,而其它部分不同;或者一個單元格中的數字結尾部分和另一個單元格中的數字的中間部分相同;等等。

copyright © 萬盛學電腦網 all rights reserved