こんばんは。
VBAについて聴きたいです。プログラムの経験は全くないので、どなたか教えていただけないでしょうか?
質問は昨日とほぼ同じですが、()が二重になった場合はどうすれば良いでしょうか?以下は質問になっております。
C15セルのテキストを分析して、項目とデータのペアを作成し、D列に項目、E列にデータという形式で出力してください。
AMP=$AWR29,SISP=BBWE,BLCK=(OLD,(30,20),CLEAN,CLEAN),CNIY=(DUSDA,3),GREEN=CB,SPACE=(GLU,RED)
=の前の文字列を項目列で、
=の後の文字列(,(,))を含む、データ列にしたいです。
以上です。どうぞ宜しくお願い致します。
No.2ベストアンサー
- 回答日時:
昨日の続き
Sub SeparateData2()
Dim RegEx As Object
Dim Ms, m
Dim sData As String
Dim cnt As Long, i As Long
Dim ArBuf, buf, n
Set RegEx = CreateObject("VBScript.RegExp")
With RegEx
.Global = True: .IgnoreCase = True: .MultiLine = True
.Pattern = "(,)([A-Z]{3,}=)" 'アルファベット3文字以上 = の意味
End With
'------------Beginning -------
sData = Range("C17").Value
cnt = Len(sData) - Len(Replace(sData, "=", "")) '=の数
ReDim Ar(cnt, 1) '格納用の配列変数
Set Ms = RegEx.Execute(sData)
buf = sData
For Each m In Ms
With m.SubMatches
buf = Replace(buf, .Item(0) & .Item(1), ";" & .Item(1), , 1)
End With
Next
ArBuf = Split(buf, ";")
For Each n In ArBuf
Ar(i, 0) = Split(n, "=")(0)
Ar(i, 1) = Split(n, "=")(1)
i = i + 1
Next
Range("D1").Resize(, 2).Value = Array("項目", "データ")
Range("D2").Resize(cnt, 2).Value = Ar
End Sub
No.3
- 回答日時:
お疲れさまです。
他の方が回答いただいているので、いらないとは思いますが、ヒントだけ記載させて頂きます。
InStrRev
を使用すると、))の後ろの側の場所を取得することができます。
大変だと思いますが、頑張ってください。
マクロを記載しても良かったのですが、自分で考えてもらった方が将来役立つと思い記載しませんでした。
失礼します。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- システム CSVファイルのマッピング処理の省力化 1 2022/11/24 00:01
- Visual Basic(VBA) 列と行の名前(重複あり)が交差するセルに、データを入力したい 2 2022/06/25 22:42
- Visual Basic(VBA) VBAで、1つのエクセルで、2つのシートからもう1つのシートに条件のある転記コードを教えてください。 1 2023/03/16 18:07
- Visual Basic(VBA) 【VBA】データを入力後に,同一シート内に履歴として転記するVBAコードを教えていただきたいです。 3 2022/11/16 01:37
- Excel(エクセル) 表示形式、文字列セル(列)に数式を入力するには マクロ 1 2022/09/18 10:53
- Visual Basic(VBA) 列と行の名前(重複あり)が交差するセルに、データを入力したい 3 2022/06/12 11:17
- C言語・C++・C# [C言語] コメント文字列を無視して、数値データを読み込むプログラム部分について 5 2022/10/05 11:03
- Excel(エクセル) [オートフィルター]機能について 3 2023/02/04 14:32
- Excel(エクセル) Excel 表の作成について 3 2022/06/16 12:15
- Excel(エクセル) Countifよりも早く重複数をカウントする方法ありますか? 18 2022/07/04 13:39
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
Excel2017 フィルタ昇順並びがA...
-
オートフィルタ後のデータから...
-
Excelで並び替え後にア行...
-
エクセルで行の高さ及び列幅の...
-
マクロで行の高さを設定したい
-
【Excel VBA】指定した行の最大...
-
基準日以前のデータを範囲を指...
-
プルダウンに【なし、平均、デ...
-
文字列を比較し、相違するフォ...
-
時間の重複チェック
-
急ぎ!色のついたセルを非表示...
-
エクセルの時刻のカウントが出...
-
列と行の名前(重複あり)が交...
-
矩形範囲の複数列を縦1列に並...
-
エクセル関数について
-
特定の行を選択して別のシート...
-
エクセル VBA 行間隔を飛ばした...
-
EXCELで日付を比べ3か月以内の...
-
複数回答のクロス集計の方法
-
excel / ピポッド 日数を出したい
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
Excel2017 フィルタ昇順並びがA...
-
エクセルで行の高さ及び列幅の...
-
Excelで並び替え後にア行...
-
急ぎ!色のついたセルを非表示...
-
【Excel VBA】指定した行の最大...
-
エクセル関数について
-
オートフィルタ後のデータから...
-
エクセルの時刻のカウントが出...
-
文字列を比較し、相違するフォ...
-
Excelで教えてください。 入力...
-
EXCEL 最終行のデータを他のセ...
-
基準日以前のデータを範囲を指...
-
EXCELで日付を比べ3か月以内の...
-
マクロで行の高さを設定したい
-
エクセル VBA 行間隔を飛ばした...
-
エクセル関数について
-
プルダウンに【なし、平均、デ...
-
時間の重複チェック
-
excel / ピポッド 日数を出したい
-
VBA 複数行の検索及び抽出
おすすめ情報