お世話になります。
以下の条件で動作するマクロを必要としています。
詳しい方、ご教授のほどよろしくお願いします。
細かな条件もあり恐縮です。一部無理でも結構です。
1.複数のcsvファイルのデータを1つのエクセルファイルにコピー統合したい。
2.ファイル名は「帳票00」~「帳票10」となっており、番号順に開いてコピーする。
3.ファイルは一部「帳票5(1)」「帳票5(2)」と分かれている。
4.ファイルは一部「帳票7」の次が「帳票9」(8は欠番)などととなっている。
5.コピーは行列を入れ替えてコピーする。
6.2つ目以降のファイルをコピーする位置は、前ファイルの次の行からとする。
(帳票00が10行まで入っていたら、帳票01は11行A列から入るようにする。)
7.2つ目の「帳票01」以降はA列B列はコピー不要とする。
(A列B列は見出しとなっていて、はじめに1回コピーされればよい。)
No.2ベストアンサー
- 回答日時:
>ファイル名の番号の若い順から開くにはどうすればよいでしょうか。
3&4の回答で書いたDirのあとソートすればできます。
以下はサンプルです。
-----------------------------------------------
Sub ファイルリスト作成()
'初期設定
Dim Line As Long
Dim Filename As String
Dim Filenames As String
Sheet1.Cells.ClearContents
'リスト作成
Line = 1
Filename = Dir(ThisWorkbook.Path & "\*.*")
Do While Filename <> ""
Filenames = StrConv(Filename, vbLowerCase)
If Not (Filenames Like "*.xls" Or Filenames Like "*.bat" ) _
Then
Line = Line + 1
Cells(Line, 1) = Filename
End If
Filename = Dir()
Loop
If Line = 1 Then
MsgBox "対象となるファイルがありません"
Exit Sub
End If
'ソート
[A1].Select
Selection.Sort Key1:=Range("A1"), Order1:=xlAscending, Header:=xlYes, _
OrderCustom:=1, MatchCase:=False, Orientation:=xlTopToBottom, SortMethod _
:=xlPinYin
End Sub
No.1
- 回答日時:
こんばんは
とりあえずすぐに回答できるところから。
1&2
csvを順次「Worksheets.Open」で開きコピー&ペーストします。
3&4
「元データのcsvファイルがすべて同じフォルダにある」&「そのフォルダには余計なcsvファイルは置かれていない」という条件なら、Dir関数を使って対象ファイルのリストを作ることができます。
5
PasteSpecial メソッドの「Transpose」のオプションで設定できます。
マクロの記録で、形式を指定して貼り付け(行列を入れ替えるにチェック)で試してみてください。
6&7
Ifで分岐できます。
質問にはありませんが元データのcsvファイルの最終行を取得するには
Cells(Rows.Count, "A").End(xlUp).Row
が使えます。(バージョン2000~2007に対応、エクセルの最終行までデータが入っていないことが条件)
以上、参考になれば。
追加で回答できる部分があれば、改めて回答します。
また、詳細が分からない場合には、「補足」に書き込みしてください。
この回答への補足
早速のご回答ありがとうございます。
補足ですが、ファイルは実際は100個ほど同じフォルダ内にあります。
他に余計なファイルはありません。
ファイル名の番号の若い順から開くにはどうすればよいでしょうか。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) エクセルのマクロについて教えてください。 4 2023/05/24 08:33
- Visual Basic(VBA) excelにて、特定の列に数字入力してあれば、入力してある行コピーして 別ファイルに張り付ける 2 2022/08/11 05:33
- Excel(エクセル) 【困っています】VBA 追加処理の記述を教えてください。 1 2022/08/25 22:54
- Visual Basic(VBA) エクセルのマクロについて教えてください。 1 2023/08/03 11:27
- Visual Basic(VBA) エクセルのマクロについて教えてください。 1 2023/08/03 12:30
- Visual Basic(VBA) Excelのマクロについて教えてください。 1 2023/03/12 12:16
- Excel(エクセル) エクセルのマクロについて教えてください。 3 2023/02/07 14:47
- Visual Basic(VBA) サブフォルダ(データ)にある複数の.xlsxファイルのSheet3のA2セルの値で01から左側をB2 2 2022/08/14 15:46
- Excel(エクセル) Excel ハイパーリンク設定について 教えてください 例なんですが、 VBAにてファイル1の列Gに 2 2022/11/04 17:52
- Outlook(アウトルック) 【 Windows 10 】アドレス帳に正しくインポートを完了させたい。 3 2023/04/23 13:41
関連するカテゴリからQ&Aを探す
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
Excelのマクロについて教えてく...
-
エクセルで複数のコメントのサ...
-
バッチファイル 別ファイルにリ...
-
frxファイルの役目
-
パワポでスライドをコピーでき...
-
bat 同名ファイルコピー時にリ...
-
バッチファイル XCOPYで上書き...
-
xcopyでのバッチコピー方法でコ...
-
VBSで作成したフォルダにファイ...
-
Tabctl32.ocxについて
-
ファイルサーバ上のファイルが...
-
特定のエクセルファイルが止ま...
-
VBAでXCOPYの実行結果を取得したい
-
サブフォルダ(データ)にある...
-
batでのスタートアップです
-
PCの中に保存されているファイ...
-
外付けハードディスクに保存し...
-
ExcelのVBA使用ファイルが保存...
-
LAN接続HDD(LinkStation)で削...
-
[エクセル]コピーするとオブジ...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
エクセルで複数のコメントのサ...
-
バッチファイル XCOPYで上書き...
-
frxファイルの役目
-
エクセルVBAで開いているファイ...
-
エクセルのハイパーリンクがコ...
-
[エクセル]コピーするとオブジ...
-
バッチファイル 別ファイルにリ...
-
Vba初心者です。下記のコード助...
-
ファイルサーバ上のファイルが...
-
Gitについて質問。 クローンし...
-
エクセル2010、図が大きすぎま...
-
バッチファイルのコピーで
-
現在のブックを閉じないで、マ...
-
エクセルのマクロについて教え...
-
vbsでExcelのシートをコピーす...
-
同じファイル名 上書きしないフ...
-
アクセス クエリを別のファイ...
-
マインクラフトPCをプレイしよ...
-
xcopyでのバッチコピー方法でコ...
-
開いている別のファイルにExcel...
おすすめ情報