
お世話になります。
初級者ですが、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で質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
Excel: ファイル名になぜ、[...
-
エクセルのファイル:「自分」が...
-
ファイルが移動してもリンクの...
-
彼女の過去の恋愛に嫉妬してし...
-
iCloud for Windowsをアンイン...
-
htmlファイルを結合して一つの...
-
CSVファイルの特定行の削除
-
ネットワークオーディオ使用時...
-
[Unity]シーンファイルの中が消...
-
複数のExcelファイルにある同名...
-
自動で.xlsを閉じて指定フォル...
-
5000個のtiffファイルをpdfへ変...
-
エクセルでブックを閉じたとき...
-
VB6 Form内のDragDrop
-
ファイルの同一性を判定するID...
-
liveupdateが完了しない
-
Excel VBA 指定のフォルダ内の...
-
EXCELVBAにて文字列にして「01...
-
VBAにおいて、ファイルの移...
-
「セキュリティの警告 発行元...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
Excel: ファイル名になぜ、[...
-
エクセルのファイル:「自分」が...
-
彼女の過去の恋愛に嫉妬してし...
-
CSVファイルの特定行の削除
-
ファイルが移動してもリンクの...
-
複数のExcelファイルにある同名...
-
EXCELVBAにて文字列にして「01...
-
xlsファイルが開かない。
-
vbsからのExcelマクロ呼び出し...
-
CSVファイルの暗号化
-
FTPのgetとputの使いわけ。
-
docxをmht形式で保存したファイ...
-
iCloud for Windowsをアンイン...
-
VBA ファイル一覧を取得して全...
-
[Unity]シーンファイルの中が消...
-
VBSでフォルダ内の最新のファイ...
-
VBAにおいて、ファイルの移...
-
このファイルは外部のエディタ...
-
batでファイル名を変更したい(...
-
フォルダ内の複数のファイルの...
おすすめ情報