いつもお世話になっております
以前頂戴しました
OrderTEXT のコードで
範囲をA-H列まで広げたいのです
おしえてくれませんでしょうか
Const Target = "A4:H8" '←----------この部分をかえてもうまくいきませんでした。
'←----------もともとはConst Target = "A4:B8"
Const orderText = "ぶどう,なし,りんご,みかん,メロン"
Dim data, order
Dim i As Long, j As Long
Dim r As Range, k As String
order = Split(orderText, ",")
data = Range(Target).Value
Set r = Range(Target)(1, 1) '←---------- いじりましたが?
For i = LBound(order) To UBound(order)
k = order(i)
r.Value = k
For j = LBound(data) To UBound(data)
If data(j, 1) = k Then
r.Offset(0, 1).Value = data(j, 2) '←----------この部分をかえてもうまくいきませんでした。。 '←---------- data(j, 2) data(j, 8)
Exit For
End If
Next j
Set r = r.Offset(1, 0) '←---------- ここは書き出しなので関係ないかも
Next i
よろしくお願いいたします。
No.3ベストアンサー
- 回答日時:
的外れな回答かもですが。
項目行は無視してデータを下に別表として『商品名』の順序を変えて書き出す例です。
Sub megu()
Const Target = "A4:H8" '←----------この部分をかえてもうまくいきませんでした。
'←----------もともとはConst Target = "A4:B8"
Const orderText = "なし,りんご,ぶどう,メロン,みかん" '←---------★故意に順番を変更
Dim data, order
Dim i As Long, j As Long, n As Long
Dim r As Range, k As String
order = Split(orderText, ",")
data = Range(Target).Value
Set r = Range(Target).Cells(1, 1).Offset(8) '←---------- いじりましたが? ★下に別表として書き出す
For i = LBound(order) To UBound(order)
k = order(i)
r.Value = k
For j = LBound(data) To UBound(data)
If data(j, 1) = k Then
For n = 2 To UBound(data, 2) '★列方向の書き出し
r.Offset(0, n - 1).Value = data(j, n) '←----------この部分をかえてもうまくいきませんでした。。 '←---------- data(j, 2) data(j, 8)
Next n
Exit For
End If
Next j
Set r = r.Offset(1, 0) '←---------- ここは書き出しなので関係ないかも
Next i
End Sub
いつも有難うございます。
これでは私ではわかりませんです。
Set r = Range(Target).Cells(1, 1).Offset(8)はいじってはみましたが
とても難しいです
有難うございます。
No.2
- 回答日時:
No.1です。
でもこれってあるシートのセル範囲を配列にして、その配列を再度『同じシートに?』書き出しそうとしているのは不思議な感じなのですが、目的としてはそうなのでしょうか?
とくにシートの指定がないので読み込みも書き込みもアクティブシートが対象ですよね?
No.1
- 回答日時:
元の質問や今回したい事が不明なので参考にならないかもですが。
>Const orderText = "ぶどう,なし,りんご,みかん,メロン"
これって必要なのでしょうか?
『商品名』欄が変更される度に書き換えなきゃいけない手間がかかりそうに思います。(今回限りの物であるならそれでも良いでしょうけど)
個人的には商品の列にある値を取得する事で変更に対応しやすくするって方法を選択しますけど。
あとはやりたい事が不明なので回答を控えますが、A~B列だったものをA~H列に変更したいのならそれに見合った『列』を与えるなどを考えないと、
そのコードでは以前のA~B列仕様のままだと思えますけど。(未検証なので自信はありませんが)
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) excel vbaでvlooupの変数がわかりません。 7 2022/05/30 09:35
- Excel(エクセル) VBAの指示の内容 昨日こちらでご教示頂いたのですが初心者な為、一つ一つの指示が何をやっているのかわ 2 2022/10/25 18:08
- Visual Basic(VBA) VBA処理追加 こちらでご教示頂いたのですが回答完了させてしまいましたのでこちらからまた質問させてく 2 2022/10/27 09:57
- Visual Basic(VBA) vba 重複データ合算 5 2023/07/05 18:55
- Excel(エクセル) エクセルVBAでオブジェクトが必要です 2 2022/09/10 16:37
- Visual Basic(VBA) 稀に1円合いません? Sheet1から金額と個数を貼り付ける下記コードで、金額を切り上げるコードを何 3 2022/09/05 15:11
- Excel(エクセル) VBAについて 3 2022/06/19 18:19
- Visual Basic(VBA) 別シートのデータを参照して値を入れたい。 まとめデータシートのC列D列の値を商品一覧シートのコードが 7 2022/08/17 13:20
- Visual Basic(VBA) 複数シート一括作成後に、特定範囲の数式は値で貼り付けしたい 3 2022/10/07 11:18
- Visual Basic(VBA) 【追加】ファイルを閉じてダイアログで保存した時だけ処理の実行をする 3 2022/03/23 15:43
関連するカテゴリからQ&Aを探す
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
ポインター引数の関数でコンパ...
-
stable diffusionのエラー
-
エクセルVBA:日付データの変換...
-
C言語について
-
c言語の多次元配列で1から100ま...
-
オセロゲーム 2次元配列で困...
-
matlabのソースコードをpython...
-
printfの%eで指数部分の桁数を...
-
C++/CLIのオブジェクト型配列
-
C#でのswitch文
-
(C言語・配列)date[i]の分散...
-
c言語での wavファイルの編集(...
-
c言語 配列から数字だけをint型...
-
【Excel VBA】10進数を2進数に...
-
pythonでDBのカラム名で取得し...
-
10Mバイトて文字数に すると何...
-
UTF-8で5~6バイトになる文字コ...
-
エクセルシート名の制限を変更...
-
Excel 1セル当りの文字数が2...
-
バイナリとBCDコード
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
ポインター引数の関数でコンパ...
-
stable diffusionのエラー
-
printfの%eで指数部分の桁数を...
-
【Excel VBA】10進数を2進数に...
-
int型(2バイト)データの分割
-
pythonでDBのカラム名で取得し...
-
エクセルVBA:日付データの変換...
-
C#でのswitch文
-
C言語の構造体にてバブルソート...
-
c言語での wavファイルの編集(...
-
linuxのシェルでファイル名に先...
-
'dataType' 引数を Null にする...
-
オセロゲーム 2次元配列で困...
-
H8/36064を使ったシリアル通信...
-
c言語の多次元配列で1から100ま...
-
c言語 配列から数字だけをint型...
-
10個の実数に対する降順ソート...
-
matlabのソースコードをpython...
-
Cのプログラムがどうしても動き...
-
テキストファイルの結合について
おすすめ情報
いつもお世話になっております
個人的には商品の列にある値を取得する事で変更に対応しやすくするって方法を選択しますけど。
わたしも同感ですとなりますと
Const orderText = "ぶどう,なし,りんご,みかん,メロン"
ここをrange("A3:A8")にして考えます。
ありがとうございます。
その通りです。
For j = LBound(data) To UBound(data)
If data(j, 1) = k Then
r.Offset(0, 1).Value = data(j, 2) '←----------配列の列の部分なので関係ないです。
となるとr.offset(0,8).valueだとだめですし
set r.offset(1) わかりません