Excel VBA質問箱 IV

当質問箱は、有志のボランティア精神のおかげで成り立っています。
問題が解決したら、必ずお礼をしましょうね。
本サイトの基本方針をまとめました。こちら をご一読ください。

投稿種別の選択が必要です。ご注意ください。
迷惑投稿防止のため、URLの入力を制限しています。ご了承ください。


34599 / 76734 ←次へ | 前へ→

【47342】Re:重複文字の削除
回答  ウッシ  - 07/3/8(木) 15:21 -

引用なし
パスワード
   こんにちは

「最後のN10、N20を残して」という事は順番も重要なのでしょうか?
「JOIN」だと順番が狂うようなので、文字連結で誤魔化すと、
Sub test()
  Dim v   As Variant
  Dim A   As String
  Dim B   As String
  Dim i   As Long
  Dim m1Dic As Object
  
  A = "N10,N20,N50,N10,N100,N10,N20"
  v = Split(A, ",")
  If IsEmpty(v) Then Exit Sub
  Set m1Dic = CreateObject("Scripting.Dictionary")
  For i = UBound(v) To LBound(v) Step -1
    If Not IsEmpty(v(i)) Then
      If Not m1Dic.Exists(v(i)) Then
        B = v(i) & "," & B
        m1Dic(v(i)) = v(i)
      End If
    End If
  Next
  MsgBox Left(B, Len(B) - 1)
  Set m1Dic = Nothing
End Sub

「JOIN」版
Sub test1()
  Dim v   As Variant
  Dim A   As String
  Dim B   As String
  Dim i   As Long
  Dim m1Dic As Object
  A = "N10,N20,N50,N10,N100,N10,N20"
  v = Split(A, ",")
  Set m1Dic = CreateObject("Scripting.Dictionary")
  
  For i = UBound(v) To LBound(v) Step -1
    m1Dic(v(i)) = v(i)
  Next
  MsgBox Join(m1Dic.items, ",")
  Set m1Dic = Nothing
End Sub

3 hits

【47337】重複文字の削除 なた 07/3/8(木) 10:43 質問
【47338】Re:重複文字の削除 neptune 07/3/8(木) 12:18 発言
【47340】Re:重複文字の削除 なた 07/3/8(木) 13:41 発言
【47342】Re:重複文字の削除 ウッシ 07/3/8(木) 15:21 回答
【47377】Re:重複文字の削除 なた 07/3/9(金) 10:34 お礼

34599 / 76734 ←次へ | 前へ→
ページ:  ┃  記事番号:
2610219
(SS)C-BOARD v3.8 is Free