お世話になります。
初級者ですが、Excel 2002のVBAについてご質問をさせて頂きます。
【概要】
あるフォルダ内にある複数のExcelファイルの、特定のセルを
1つのExcelファイルに集約します。
【詳細】
1.あるフォルダ内に複数のExcelファイルがあります。Excelファイルの数は、その日によって
ことなります。
2.選択画面から、この複数のExcelファイルを選択し、選択したExcelファイルの
それぞれの「A1セル」「B1セル」「C1セル」を、「1つのExcelファイル」に張り付けます。
3.「貼り付け」→「次の列へ移動」→「貼り付け」→「次の列へ移動」というサイクルを、
選択したExcelファイルの数だけ繰り返します。
4.集約したExcelファイルのイメージは以下のとおりです。
A列 B列 C列 D列 E列 F列 G列 H列 。。。。
1行目 A1 A1 A1 A1 A1 A1 A1 A1 。。。。
2行目 B1 B1 B1 B1 B1 B1 B1 B1 。。。。
3行目 C1 C1 C1 C1 C1 C1 C1 C1 。。。。
教えて!gooの回答で、「複数のシートを、1つのExcelファイルに集約する」ものがあったので、
それを参考にしようとしましたが、僕の実力ではできませんでした。
ご助言を頂けると非常に助かります。よろしくお願いします。
No.3ベストアンサー
- 回答日時:
一例です。
ただ、シート名に一切言及がなかったので、複数選択した転記元ファイルについては開いたときに表示されるシート、転記先はこのマクロを書いたファイルのSheet1という名前のシートを対象としました。
フォルダを選択したら、対象とする複数のファイルを選択してください。(Ctrlボタンを押しながらファイルを選べば複数ファイルの選択ができます。)
Sub test01()
Dim Bks, wb
Bks = Application.GetOpenFilename(FileFilter:="Microsoft Excelブック,*.xls", MultiSelect:=True)
If IsArray(Bks) Then
Application.ScreenUpdating = False
For Each wb In Bks
Workbooks.Open wb
n = n + 1
ActiveSheet.Range("A1:C1").Copy
ThisWorkbook.Sheets("Sheet1").Cells(1, n).PasteSpecial Paste:=xlPasteAll, Transpose:=True
Application.CutCopyMode = False
ActiveWindow.Close (False)
Next
Application.ScreenUpdating = True
Else
MsgBox "キャンセル"
End If
End Sub
的確なアドバイス、有難う御座います。
僕のイメージどおりの、集約したExcelファイルができました。
今後、「F1」「A3」など、飛び飛びのセルも集約の対象になる見込みなのですが、
merlionXXさんのアドバイスを参考にさせて頂いて、対応したいと思います。
No.2
- 回答日時:
基本的には、>あるフォルダ内にある複数のExcelファイル、はすべて処理対象にするのだろう?
そのうち処理対象からはずすのはあるのか(集約ブックは別として)?。そのために操作者への表示と確認が必要なのか。
ーー
初心者といって、ここに質問する前に、あるフォルダのすべてのファイル(エクセルファイルだけでも良い)を掴むコードを勉強するべきだ。Googleで照会すれば沢山あるはず。ここへの質問もたびたび出てくる。
Googleで「フォルダ すべて ファイル 列挙」などで照会する。
http://www.asahi-net.or.jp/~ef2o-inue/vba_o/sub0 … など。
定石としてVBSでやる方法、DIR関数、その他がある。
下記はVBSをつかう。エクセルのブック(データを集約するブックででも)の標準モジュールに
Sub test01()
On Error Resume Next
Dim FSO 'Scripting.FileSystemObject
Dim objFolder 'Folderオブジェクト
Dim oFile 'Fileオブジェクト
Set FSO = CreateObject("Scripting.FileSystemObject")
Set objFolder = FSO.GetFolder("C:\Documents and Settings\XXXX\My Documents\")
For Each oFile In objFolder.Files
If Right(oFile, 4) = ".xls" Then
MsgBox oFile.Name
End If
Next
End Sub
ーー
ファイルをとらえたら、エクセルでOpen する。
そのブックのシートSheet1のA1セルなどの値を掴む。
Sub test01()
Application.ScreenUpdating = False
Application.DisplayAlerts = False
On Error Resume Next
Dim FSO 'Scripting.FileSystemObject
Dim objFolder 'Folderオブジェクト
Dim oFile 'Fileオブジェクト
Set FSO = CreateObject("Scripting.FileSystemObject")
Set objFolder = FSO.GetFolder("C:\Documents and Settings\XXXX\My Documents\")
For Each oFile In objFolder.Files
If Right(oFile, 4) = ".xls" Then
'MsgBox oFile.Name
Workbooks.Open oFile
MsgBox Worksheets("Sheet1").Range("A1")
ActiveWorkbook.Close SaveChanges:=True
End If
Next
Application.ScreenUpdating = True
Application.DisplayAlerts = True
End Sub
ーーーー
集約するブックへのコードはA->Bブックの例でマクロの記録を採って考えてみては。
でもさらに色々疑問点はあろうが、1つ1つやるほか無い。そういう疑問点の質問ににこのコーナーは使うべきだ。
早急なアドバイス、有難う御座います。
>集約するブックへのコードはA->Bブックの例でマクロの記録を採って考えてみては。
でもさらに色々疑問点はあろうが、1つ1つやるほか無い。そういう疑問点の質問ににこのコーナーは使うべきだ。
→imogasiさんのいうとおり、僕がもう少し努力をしてから質問をすべきでした。
今後はそのようにします。
No.1
- 回答日時:
とりあえず複数のファイルを選択して開く
↓の最後にやり方があります。
http://officetanaka.net/excel/vba/file/file02.htm
> Excelファイルの数だけ繰り返します
これも上記のサイトが参考になります。
あとは説明するまでもないですよね。
アドバイスを頂きまして、有難う御座います。
URLを確認しました。
様々な方法があるのですね、勉強になります。
>あとは説明するまでもないですよね。
→ファイル選択後の処理も、今の僕には難しいですが、
努力してみます。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Excel(エクセル) Excelの空文字判定について 7 2023/01/06 13:25
- Visual Basic(VBA) Excel VBA 最終行を取得しVlookup関数をコピーする方法をコーディングで教えてください。 3 2023/05/11 13:14
- Excel(エクセル) Excel表示形式 2 2022/09/09 09:57
- Excel(エクセル) エクセルの関数式を教えてください。 2 2022/11/29 21:09
- Excel(エクセル) エクセルVBAでセルに表示されているとおりの数値を取得したい(時間の計算結果) 1 2022/03/30 17:52
- Excel(エクセル) 複数の同じ様式のエクセルデータの任意セルへの入力について 3 2022/04/27 15:00
- Excel(エクセル) エクセルの掛け算 3 2022/12/13 14:49
- Visual Basic(VBA) サブフォルダ(データ)にある複数の.xlsxファイルのSheet3のA2セルの値で01から左側をB2 2 2022/08/14 15:46
- Excel(エクセル) excelで検索した商品の画像(ネットワーク上の)を表示させたい。 3 2023/06/28 00:32
- Excel(エクセル) Excelの関数についての質問です。(vlookup関数) A列 B列. C 1 大阪 50. 検索 6 2023/08/11 13:35
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・「みんな教えて! 選手権!!」開催のお知らせ
- ・漫画をレンタルでお得に読める!
- ・【選手権お題その2】この漫画の2コマ目を考えてください
- ・2024年に成し遂げたこと
- ・3分あったら何をしますか?
- ・何歳が一番楽しかった?
- ・治せない「クセ」を教えてください
- ・【大喜利】看板の文字を埋めてください
- ・【大喜利】【投稿~12/17】 ありそうだけど絶対に無いことわざ
- ・【選手権お題その1】これってもしかして自分だけかもしれないな…と思うあるあるを教えてください
- ・【穴埋めお題】恐竜の新説
- ・我がまちの「給食」自慢を聞かせてっ!
- ・冬の健康法を教えて!
- ・一番好きな「クリスマスソング」は?
- ・集合写真、どこに映る?
- ・自分の通っていた小学校のあるある
- ・フォントについて教えてください!
- ・これが怖いの自分だけ?というものありますか?
- ・スマホに会話を聞かれているな!?と思ったことありますか?
- ・それもChatGPT!?と驚いた使用方法を教えてください
- ・見学に行くとしたら【天国】と【地獄】どっち?
- ・これまでで一番「情けなかったとき」はいつですか?
- ・この人頭いいなと思ったエピソード
- ・あなたの「必」の書き順を教えてください
- ・10代と話して驚いたこと
- ・14歳の自分に衝撃の事実を告げてください
- ・人生最悪の忘れ物
- ・あなたの習慣について教えてください!!
- ・都道府県穴埋めゲーム
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
エクセルのマクロについて教え...
-
彼女の過去の恋愛に嫉妬してし...
-
thunderbirdで特定のメールだけ...
-
iCloud for Windowsをアンイン...
-
htmlファイルを結合して一つの...
-
エクセルのファイル:「自分」が...
-
ASP.NETでINIファイル読込みを...
-
ネットワークオーディオ使用時...
-
特定のフォルダー内のエクセル...
-
CSVファイルの暗号化
-
ImageJのマクロ機能についてです
-
CSVファイルの特定行の削除
-
vbsからのExcelマクロ呼び出し...
-
batでファイル名を変更したい(...
-
PTBファイルの変換
-
「このファイルを開く前に常に...
-
デスクトップ画面に「◯◯まであ...
-
非表示だった「セキュリティの...
-
サイズが2GBを越えるファイルを...
-
Windows上のマウス操作をプログ...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
CSVファイルの特定行の削除
-
iCloud for Windowsをアンイン...
-
彼女の過去の恋愛に嫉妬してし...
-
Excel: ファイル名になぜ、[...
-
[Unity]シーンファイルの中が消...
-
vbsからのExcelマクロ呼び出し...
-
WINDOWS CMDからゴミ箱のファ...
-
ファイルが移動してもリンクの...
-
複数のExcelファイルにある同名...
-
EXCELVBAにて文字列にして「01...
-
FTPのgetとputの使いわけ。
-
自動で.xlsを閉じて指定フォル...
-
docxをmht形式で保存したファイ...
-
エクセルのファイル:「自分」が...
-
VBAにおいて、ファイルの移...
-
エクセルの固定範囲にCSVを貼り...
-
5000個のtiffファイルをpdfへ変...
-
mediaplayerの取り込みフォルダ...
-
File.delete()にてファイルを削...
-
このファイルは外部のエディタ...
おすすめ情報