• ベストアンサー

エクセル表の並び替えに関して

エクセル2002です。 --- K1|K2|K3|K4| ---------------- 9/2|A |- |B |- | 9/3|- |A |A |B | 9/4|B |- |A |B | 9/5|- |- |- |A | を A|K1|9/2|---|---| A|K2|9/3|---|---| A|K3|9/3|9/4|---| A|K4|9/5|---|---| B|K1|9/4|---|---| B|K2|---|---|---| B|K3|9/2|---|---| B|K4|9/3|9/4|---| と別の場所あるいはべつのシートに並び替える方法はあるでしょうか?--の部分は空白です。 元表の列も行も増える可能性があります。 すみませんがぜひよろしくお願いいたします。

質問者が選んだベストアンサー

  • ベストアンサー
  • BLUEPIXY
  • ベストアンサー率50% (3003/5914)
回答No.2

Public Sub convert() Dim r As Range Dim base As Range Set r = ActiveCell.CurrentRegion 'アクティブセルのある範囲 'Set r = Selection '範囲を指定 SYMBOLS = "ABCDEFGHIJKLMNOPQRSTUVWXYZ" SYMLEN = Len(SYMBOLS) Set base = Range("sheet2!A1") '書き込みの基準位置 ActiveWorkbook.Sheets("sheet2").Range("1:65536").ClearContents '書き込み先の消去 xMax = r.Columns.Count yMax = r.Rows.Count dataC = 0 valueC = 0 For i = 1 To SYMLEN code = Mid$(SYMBOLS, i, 1) For x = 2 To xMax For y = 2 To yMax If r.Cells(y, x) = code Then If valueC = 0 Then base.Offset(dataC, 0).Value = code base.Offset(dataC, 1).Value = r.Cells(1, x) base.Offset(dataC, 2).Value = r.Cells(y, 1) base.Offset(dataC, 2).NumberFormatLocal = "m/d" '書式の設定 valueC = 3 Else If base.Offset(dataC, 0) = code And base.Offset(dataC, 1) = r.Cells(1, x) Then base.Offset(dataC, valueC).Value = r.Cells(y, 1) base.Offset(dataC, valueC).NumberFormatLocal = "m/d" '書式の設定 valueC = valueC + 1 Else dataC = dataC + 1 base.Offset(dataC, 0).Value = code base.Offset(dataC, 1).Value = r.Cells(1, x) base.Offset(dataC, 2).Value = r.Cells(y, 1) base.Offset(dataC, 2).NumberFormatLocal = "m/d" '書式の設定 valueC = 3 End If End If End If Next y Next x Next i End Sub とりあえず、作ってみました。 B|K2は、データなしで表示(処理)しないようになっています。 該当の表の中のセルをセレクトしておいてマクロを呼び出します。 結果は、"sheet2"へ書き出します

takashiro
質問者

お礼

ありがとうございます。参考にさせていただき、勉強させていただきたいと思います。 もっと簡単なものと考えていたのですが、自分の未熟さを痛感しています。 ありがとうございました。

その他の回答 (1)

  • imogasi
  • ベストアンサー率27% (4737/17069)
回答No.1

関数による解答を期待しておられるかもしれませんが、 難しいと思います。Sheet2のあるセルを考えた時、そこにくるべきSheet1のセルがどこかを式で割り出すことは、非常に複雑になると思われ、事実上不可能でしょう。 するとVBAを使うことになりますが、VBAでも少し経験がないと、ロジックが難しい。取りあえず近いところまでやって見ましたた。 Sheet1のB2:E5を範囲指定して実行します。 Sub test01() Dim sh1, sh2 As Worksheet Dim cl As Range Set sh1 = Worksheets("sheet1") Set sh2 = Worksheets("sheet2") j = 1 For Each cl In Selection If cl <> "-" Then sh2.Cells(j, "A") = cl sh2.Cells(j, "B") = sh1.Cells(1, cl.Column) sh2.Cells(j, "C") = sh1.Cells(cl.Row, 1) j = j + 1 End If Next '------ sh2.Range(sh2.Cells(1, "A"), sh2.Cells(j, "C")).Sort Key1:=sh2.Range("A1"), _ Order1:=xlAscending, Key2:=sh2.Range("B1"), Order2:=xlAscending '------ For i = 1 To j ' (略) Next i End Sub これで A K1 2004/9/2 A K2 2004/9/3 A K3 2004/9/3 A K3 2004/9/4 A K4 2004/9/5 B K1 2004/9/4 B K3 2004/9/2 B K4 2004/9/3 B K4 2004/9/4 になりますが、同一日を1行にまとめるのに更にプログラムコードの追加が必要です(略)。 それでも該当のないBのK2行を空白にすることが出来ていません。 K1からK4が4つとか少ないなら、むしろ違うロジックでプログラムを組む方がよいかも知れない。 それと、Sheet1で追加したら、即座にSheet2に反映するのもあきらめてください。 上記は、Sheet1のデータ入力の区切りの良いところで毎回プログラムを手動実行するものです。

takashiro
質問者

お礼

早速ありがとうございます。ちょっと自分にはレベルが高すぎる回答でした。参考にさしていただいて、勉強したいと思います。 補足ですが、A,B,K1-K4のところは手打ちしたいと思っております。 回答ありがとうございました。

関連するQ&A

専門家に質問してみよう