• ベストアンサー
※ ChatGPTを利用し、要約された質問です(原文:レーダーチャートの並び替え)

レーダーチャートの並び替え

このQ&Aのポイント
  • レーダーチャートを大量(100個以上)自動作成しており、札幌や埼玉などが含まれる順番で並び替えたいです。
  • 並び替えたい項目はD列に記入されており、北海道、青森、仙台、秋田などが含まれます。
  • 具体的な方法としては、北海道を含むグラフタイトルを最初に配置し、その後に青森、仙台、秋田などが含まれるグラフタイトルを順番に配置していくことです。

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

  • ベストアンサー
  • mitarashi
  • ベストアンサー率59% (574/965)
回答No.1

作成したグラフの並び替えでなく、下記回答のマトリクス状のグラフ作成時に所定の順番で並び替えるコードを書いてみました。完全ではありませんが、話の種に回答いたします。 http://okwave.jp/qa/q8339279.html まず、ユーザー定義リストによる並び替えは、リストが「北海道」であれば、「北海道」だけに通用し、「北海道旭川市」等はNGです。グラフタイトルのリストの隣の列に、リストにある値を分離して、その列をキーに並び替えする必要があります。下記では容易に分離できる都道府県名で試してみました。「仙台」といったデータに適用するにはループを回して照合し、一個ずつ分離する位しか思いつきません。なお、ユーザー定義リストはMax1000文字らしいので、リストがそれを超える場合は自力で並び替える必要があります。 Sub test() Dim dataRange As Range, myArea As Range, targetRange As Range 'グラフを生成するシート、タイトルの並び替えを行うシート、都道府県名のリストがあるシート Dim sh As Worksheet, sortSh As Worksheet, customListSh As Worksheet Dim Counter As Long, graphColumns As Long Dim myLeft As Double, myTop As Double, myWidth As Double, myHeight As Double Dim xOffset As Double, yOffset As Double Dim chartObj() As ChartObject Dim myDic As Object Dim myKeys As Variant Dim i As Long Dim buf As Variant Dim sortRange As Range, myCell As Range 'xl2007以降用のSortオブジェクト用のリストは定数でないと型違いエラーとなる(dim宣言ではNG) '従ってシートに置いたリストからの読み込みは出来ない Const strCustomList As String = "北海道,青森県,岩手県,宮城県,秋田県,山形県,福島県,茨城県,栃木県,群馬県,埼玉県,千葉県,東京都,神奈川県,新潟県,富山県,石川県,福井県,山梨県,長野県,岐阜県,静岡県,愛知県,三重県,滋賀県,京都府,大阪府,兵庫県,奈良県,和歌山県,鳥取県,島根県,岡山県,広島県,山口県,徳島県,香川県,愛媛県,高知県,福岡県,佐賀県,長崎県,熊本県,大分県,宮崎県,鹿児島県,沖縄県" graphColumns = 3 'グラフを何列に並べるか myWidth = 200: myHeight = 150 xOffset = 20: yOffset = 20 Set sh = Sheets(1) Set sortSh = Sheets(2) Set customListSh = Sheets(3) With sh Set dataRange = .Range(.Range("A2"), .Range("A" & .Rows.Count).End(xlUp)) End With '連想配列に収納して、キーの配列をワークシートに書き出して、エクセルの機能でソーティングし 'ソート後列の先頭から,セル値をキーにして連想配列からグラフ化するRangeを読み出しグラフを作成する Set myDic = CreateObject("Scripting.Dictionary") For Each myArea In dataRange.SpecialCells(xlCellTypeConstants).Areas Set targetRange = Intersect(myArea, myArea.Offset(1, 0)).Resize(, 3) myDic.Add targetRange.Cells(1).Item(0).Value, targetRange Set targetRange = Nothing Next myArea myKeys = myDic.keys With sortSh .Cells.Clear Set sortRange = .Range(.Range("A1"), .Range("A" & myDic.Count)) End With sortRange.Value = Application.WorksheetFunction.Transpose(myKeys) 'ユーザー定義リストによる並び替えはそのものズバリの値でないと通用しない様なので、 '隣の列に都道府県名のみ取り出して、そちらをキーに並び替える sortRange.Offset(0, 1).FormulaR1C1 = "=IF(MID(RC[-1],4,1)=""県"",LEFT(RC[-1],4),LEFT(RC[-1],3))" sortRange.Offset(0, 1).Value = sortRange.Offset(0, 1).Value Set sortRange = sortRange.Resize(, 2) 'ユーザー定義リストにより並び替え 'xl2007はVBA6.5なので、下記を実行するとSortオブジェクトが無いためコンパイルエラーになります。 'エクセルのバージョンによるコンパイル分岐の方法が分かりませんでした。 #If VBA7 Then 'xl2010 以降 sortSh.Sort.SortFields.Clear sortSh.Sort.SortFields.Add Key:=sortSh.Range("B1"), _ SortOn:=xlSortOnValues, Order:=xlAscending, CustomOrder:=strCustomList, DataOption:=xlSortNormal With sortSh.Sort .SetRange sortRange .Header = xlGuess .MatchCase = False .Orientation = xlTopToBottom .SortMethod = xlPinYin .Apply End With #Else 'xl2003以前のコード 但しxl2010で実行するとエクセルが不安定~飛びます。xl2003なら大丈夫そうです。 With customListSh Application.AddCustomList ListArray:=.Range(.Range("A1"), .Range("A" & .Rows.Count).End(xlUp)).Value End With 'CustomListCount + 1でないとNGだが、理屈は不明 sortRange.Sort Key1:=sortRange.Range("B1"), Order1:=xlAscending, Header:=xlNo _ , OrderCustom:=Application.CustomListCount + 1, MatchCase:=False, _ Orientation:=xlTopToBottom, SortMethod:=xlPinYin, DataOption1:=xlSortNormal Application.DeleteCustomList Application.CustomListCount #End If Counter = 0 For Each myCell In sortRange.Columns(1).Cells Set targetRange = myDic(myCell.Value) myLeft = 150 + (Counter Mod graphColumns) * (myWidth + xOffset) myTop = 10 + (Counter \ graphColumns) * (myHeight + yOffset) ReDim Preserve chartObj(0 To Counter) Set chartObj(Counter) = sh.ChartObjects.Add(myLeft, myTop, myWidth, myHeight) makeGraph targetRange, chartObj(Counter) Counter = Counter + 1 Next myCell End Sub Sub makeGraph(myRange As Range, myChartObj As ChartObject) '略 End Sub

satoron666
質問者

お礼

回答ありがとうございました! 毎回助けて頂いて、本当にありがとうございます!