
エクセルで以下のような「店の名前、果物名、個数、金額」が書かれた表のデータがあります。
| A | B | C | D
1|A店|りんご| 2 |400
2|A店|みかん| 3 |300
3|A店|バナナ| 4 |200
4|B店|りんご| 3 |600
5|B店|バナナ| 2 |100
これを別シートに次のようなかたちにしたいのですが、一つずつ移動する以外に方法はありますか?
| A | B | C | D | E | F | G | H | I | J
1|A店|りんご| 2 |400 |みかん| 3 | 300 | バナナ| 4 |200
2|B店|りんご| 3 |600 ||バナナ| 2 |100
エクセルの関数で処理し、できれば別シートにたいのですが、
良い方法を教えていただければ、幸いです。
なにとぞ、宜しくお願いいたします。
(別の方の質問で、果物と個数までの処理する回答がありましたが、
金額まで入れた3要素を集計する場合の関数が分かりませんでした。)
No.4ベストアンサー
- 回答日時:
こんばんは!
VBAでの一例です。
↓の画像のように元データはSheet1にあり、1行目は項目行になっているとします。
Sheet2に表示するようにしてみました。
Alt+F11キー → メニュー → 挿入 → 標準モジュール → VBE画面のカーソルが点滅しているところに
↓のコードをコピー&ペースト → Excel画面に戻り(VBE画面を閉じて)
マクロを実行してみてください。
(Alt+F8キー → マクロ → マクロ実行です)
Sub Sample1() 'この行から//
Dim i As Long, c As Range, wS As Worksheet
Set wS = Worksheets("Sheet2")
wS.Cells.Clear
With Worksheets("Sheet1")
.Range("A:A").AdvancedFilter Action:=xlFilterCopy, copytorange:=wS.Range("A1"), unique:=True
For i = 2 To .Cells(Rows.Count, "A").End(xlUp).Row
Set c = wS.Range("A:A").Find(what:=.Cells(i, "A"), LookIn:=xlValues, lookat:=xlWhole)
wS.Cells(c.Row, Columns.Count).End(xlToLeft).Offset(, 1). _
Resize(, 3).Value = .Cells(i, "B").Resize(, 3).Value
Next i
End With
wS.Rows(1).Delete
wS.Range("A1").CurrentRegion.Borders.LineStyle = xlContinuous
wS.Columns.AutoFit
End Sub 'この行まで//
※ 関数でないのでデータ変更があるたびに
マクロを実行する必要があります。m(_ _)m

早々に、ご丁寧な回答をありがとうございます。
VBAは初めてだったのですが、ご指示通り操作すればできました。
実は、10000行強のデータだったのですが、時間は3分ほどかかりましたが、
見事に変換できました。
感動しました。
本当にありがとうございました。
No.3
- 回答日時:
関数よりも「ピボットテーブル」を使った方が良いと思います。
下の図のようになります。
※レイアウトなど凝ったことはしていないので、意図したものと異なるかと思います。

「ピボットテーブル」でのご提案ありがとうございます。
この手もあったのですね。
参考にして試してみます。
ありがとうございました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
VBA横に並んでいるデータを縦に並ぶデータにしたいです。
Visual Basic(VBA)
-
エクセルで1列に500行並んだデータを5列毎に改行
Excel(エクセル)
-
エクセルで横並びの複数データを縦のデータにしたい こんにちは。宜しくお願い致します。 A B C D
ソフトウェア
-
-
4
Excel VBAで、横並びのデータを縦並びにしたい
その他(Microsoft Office)
-
5
EXCELで2列を参照し、重複するものを横に並べたい
Excel(エクセル)
-
6
VBA 縦のデータを横にするコード
IT・エンジニアリング
-
7
エクセルで縦に並んだデータを5行毎に横に並べたいです
Excel(エクセル)
-
8
エクセルで横並びの複数データを縦の一本のデータにしたい
Excel(エクセル)
-
9
エクセルで長い行を5行ごとに1列にするには?
Excel(エクセル)
-
10
エクセル 横並びの複数行データを縦1列にしたい
Excel(エクセル)
-
11
エクセル:マクロ「Application.CutCopyMode = False」って?
Excel(エクセル)
-
12
エクセルで横データを縦に並べ変えたいです。
財務・会計・経理
-
13
EXCELで「行と列を入れ替える」操作を何回も繰り返して自動実行する方法はないでしょうか?
Excel(エクセル)
-
14
VBA 連続行データを5行ずつ隣の列に貼り付ける
Excel(エクセル)
-
15
VBA横のデータを縦にする方法
Excel(エクセル)
-
16
Excelで、あるセルの値に応じて行を自動挿入したい
Visual Basic(VBA)
-
17
VBA横データを縦にしたいです
Visual Basic(VBA)
-
18
ExcelVBAを使って、値がある場合は作業を繰り返し実行するプログラムを作成したい。
Visual Basic(VBA)
-
19
エクセルでセルの値分の個数の文字列を自動で入れたい
Excel(エクセル)
-
20
Excel2000/VBA:値と書式のみ貼り付けたい。
Excel(エクセル)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
メッセージボックスのOKボタ...
-
エクセルで特定の列が0表示の場...
-
Excel_マクロ_現在開いているシ...
-
特定のPCだけ動作しないVBAマク...
-
エクセルの改ページを行ごとに...
-
マクロの連続印刷が突然不可能...
-
図形処理に適したアプリまたは...
-
エクセルで別のセルにあるふり...
-
一つのTeratermのマクロで複数...
-
Excel・Word リサーチ機能を無...
-
UWLSの記録でマクロを作成し使...
-
バッチファイルでEXCELを起動し...
-
エクセル マクロ 指定日の指定...
-
エクセルVBAでNAVITIMEを使って...
-
Worksheet_Change(ByVal Target...
-
Excel マクロ VBA プロシー...
-
エクセルVBA イベントプロシー...
-
VBA アドインについて お詳しい...
-
エクセル マクロの同時実行に...
-
マクロでのグラフタイトルの存...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
エクセルで特定の列が0表示の場...
-
特定のPCだけ動作しないVBAマク...
-
Excel・Word リサーチ機能を無...
-
一つのTeratermのマクロで複数...
-
Excel_マクロ_現在開いているシ...
-
メッセージボックスのOKボタ...
-
Excel マクロ VBA プロシー...
-
ExcelのVBA。public変数の値が...
-
エクセルに張り付けた写真のフ...
-
エクセルで別のセルにあるふり...
-
ExcelVBAでPDFを閉じるソース
-
ダブルクリックで貼り付けた画...
-
Excel マクロでShearePoint先の...
-
TERA TERMを隠す方法
-
マクロ実行時、ユーザーフォー...
-
Excelのセル値に基づいて図形の...
-
特定文字のある行の前に空白行...
-
エクセルマクロでワードの一ペ...
-
エクセルで縦に並んだデータを...
-
Excel VBAからAccessマクロを実...
おすすめ情報