EXCEL 2003のVBAでテキストファイルの取り込み方
EXCEL 2003のVBAでテキストファイルのみをとりこむものを組もうと思います。
- 読み込むテキストファイル名は一定の決まりがあります。AAxxxx.txt あるいは ZZxxx.txt といった感じで先頭文字はAAまたはZZで中のxxxは数字の可変(日付)です。
- Directoryはどこに入るか決まりがありません。(このマクロを使用するユーザーがどこのDirectoryにテキストファイルを保存しているかわからないため)
FILEN = Application.GetOpenFilename
If FILEN = False Then
Exit Sub
End If
Workbooks.OpenText Filename:=FILEN
でやると、Directoryの問題は解決しますが、テキストファイル名を絞り込めません
いい方法をご教示いただければ助かります。
No.1ベストアンサー
- 回答日時:
方法1
今のマクロでFILENが入ってるフォルダが判りますから,そこにある所定のファイルをすべて拾います。
基本形:
FILEN = application.getopenfilename
’中略
myPath = left(instrrev(filen, "\"))
myfile = dir(mypath & "*.txt")
do
if myfile like "AA*.txt" or myfile like "BB*.txt" then
msgbox myfile
end if
myfile = dir()
loop until myfile = ""
方法2
添付の参考URLなどを参考にフォルダ(ディレクトリ)を指定させ,そこにある所定のファイルを全て拾います。
フォルダを特定したあとは方法1と同じです。
http://officetanaka.net/excel/vba/tips/tips39.htm
No.4
- 回答日時:
>- Directoryはどこに入るか決まりがありません。
こういう場合は、予めリストを探して、どこかに置いておくのがふつうです。
>このマクロを使用するユーザーがどこのDirectoryにテキストファイルを保存しているかわからない
フォルダを決める方式のVBAは出来ないのは分かるけれども、オープンダイアログは、あまり関心しません。
他の方法は提供できるけれども、これ以上は、ご質問者さんの技術力も依存してしまいますが、簡単に言うと、UserForm のListBoxなどを利用して、クリックして開くなり、工夫をすればよいと思います。Excel 2003 では未だ使えるFileSearchオブジェクトか、それ以外の検索ツールを別に作らなくてはなりません。
'//
Sub OpenDialogTest1()
Dim fName As Variant 'Variant のみ
Dim myDate As String
Const sPF As String = "AA" 'プレフィックス
myDate = Format$(Date, "yymmdd") '日付
Application.SendKeys sPF & myDate & "*"
Application.SendKeys vbCr
fName = Application.GetOpenFileName("テキスト(*.txt),*.txt")
If VarType(fName) = vbBoolean Or fName = "" Then Exit Sub
'Workbooks.OpenText Filename:=fName
MsgBox fName
End Sub
'//
このコードは、環境に影響を受けますので、必ず、思った通りになるとは限りません。
なお、FILEN という名称は混乱しやすいので、やめました。FILEN というのは、ファイルサイズを連想させます。また、すべて大文字で書くと、定数を連想されます。
No.3
- 回答日時:
1.専用シート(テキストボックスとボタン)を作成し、
テキストファイルのフルパスとファイル名を
登録変更できるようにすれば使用者が設定できます。
2.毎回ダイアログを開き、ファイルを指定するようにすればできますが、
毎回、毎回めんどくさいですね。
3.ディレクトリだけの問題であれば、マクロとファイルを同じところにおいて実行してください
という決まりを作れば解決します。
No.2
- 回答日時:
>でやると、Directoryの問題は解決しますが
何が問題だったのか意味不明です。
少しプログラム的な制御コードを学びましょう。IF、while , for ,各種演算子、それに、関数ですね。文字列の検索などたくさんあるので、暇な時にヘルプを見てサンプルで試してください。
この手の質問が出る方は、そのようなヘルプ(リファレンス)をほとんど活用していません。リファレンスを見れば、この程度の初級レベルの問題であれば100%が解決します。
私なんかヘルプを見て作って売りました。
ヒントとしては、正規表現と文字列検索関数ですね。ヘルプで参照してみましょう。ヘルプが設置されていないのなら、
Excel VBA 正規表現
でネット検索。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Excel(エクセル) Excelにて、フォルダ内のTextファイルをマクロで統合すると文字化けしてしまう時の解消コード 4 2023/01/01 07:32
- Visual Basic(VBA) エクセルのマクロについて教えてください。 2 2023/07/15 15:48
- Visual Basic(VBA) VBAでエクセルをtxtに変換するとエクセルでカンマを含む文字数字がtxtでは「""」付にならないよ 1 2022/08/27 12:17
- Visual Basic(VBA) ExcelのVBAコードについて教えてください。 1 2023/08/08 15:45
- Visual Basic(VBA) エクセルのマクロについて教えてください。 2 2023/07/15 15:12
- Visual Basic(VBA) エクセルのマクロについて教えてください。 2 2023/07/21 09:42
- XML エクセルのマクロについて教えてください。 3 2023/02/06 09:06
- Visual Basic(VBA) エクセルのマクロについて教えてください。 1 2023/08/08 11:02
- Excel(エクセル) 【VBA】指定フォルダに格納中のテキストファイルをエクセルで処理し結果のエクセルを新規フォルダに保存 1 2022/03/25 14:19
- Visual Basic(VBA) 複数のcsvファイルをExcelに一括変換したい 2 2023/03/03 12:44
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・プリン+醤油=ウニみたいな組み合わせメニューを教えて!
- ・タイムマシーンがあったら、過去と未来どちらに行く?
- ・遅刻の「言い訳」選手権
- ・【大喜利】【投稿~11/12】 急に朝起こしてきた母親に言われた一言とは?
- ・好きな和訳タイトルを教えてください
- ・うちのカレーにはこれが入ってる!って食材ありますか?
- ・好きな「お肉」は?
- ・あなたは何にトキメキますか?
- ・おすすめのモーニング・朝食メニューを教えて!
- ・「覚え間違い」を教えてください!
- ・とっておきの手土産を教えて
- ・「平成」を感じるもの
- ・秘密基地、どこに作った?
- ・【お題】NEW演歌
- ・カンパ〜イ!←最初の1杯目、なに頼む?
- ・一回も披露したことのない豆知識
- ・これ何て呼びますか
- ・初めて自分の家と他人の家が違う、と意識した時
- ・「これはヤバかったな」という遅刻エピソード
- ・これ何て呼びますか Part2
- ・許せない心理テスト
- ・この人頭いいなと思ったエピソード
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・ハマっている「お菓子」を教えて!
- ・【大喜利】【投稿~11/1】 存在しそうで存在しないモノマネ芸人の名前を教えてください
- ・好きなおでんの具材ドラフト会議しましょう
- ・餃子を食べるとき、何をつけますか?
- ・あなたの「必」の書き順を教えてください
- ・ギリギリ行けるお一人様のライン
- ・10代と話して驚いたこと
- ・つい集めてしまうものはなんですか?
- ・自分のセンスや笑いの好みに影響を受けた作品を教えて
- ・【お題】引っかけ問題(締め切り10月27日(日)23時)
- ・大人になっても苦手な食べ物、ありますか?
- ・14歳の自分に衝撃の事実を告げてください
- ・【大喜利】【投稿~10/21(月)】買ったばかりの自転車を分解してひと言
- ・ホテルを選ぶとき、これだけは譲れない条件TOP3は?
- ・家・車以外で、人生で一番奮発した買い物
- ・人生最悪の忘れ物
- ・【コナン30周年】嘘でしょ!?と思った○○周年を教えて【ハルヒ20周年】
- ・あなたの習慣について教えてください!!
- ・都道府県穴埋めゲーム
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
Excelでdatファイルを作成??
-
テキストファイルの文字色に色...
-
複数のテキストファイルをexcel...
-
インデザインのテキスト流し込み
-
エクセルにpdfのテキストを表示...
-
WindowsとMac
-
ダウンロード不可PDFファイルは...
-
【Excel VBA】PDFを作成して,...
-
HTMLタグのあるCSVファイルを利...
-
ヤフーのNYダウの過去データ...
-
VBAでファイルパスが長すぎてコ...
-
XMLDOMのsaveメソッドのエラー
-
BIGLOBEのウェブリメールはフォ...
-
iniファイルをウェブ経由でアク...
-
ワードについて
-
VBSで指定したフォルダにファイ...
-
asp.netの基本的な事を教えてく...
-
Thunderbird ローカルフォルダ...
-
1フォルダに保存できるファイル...
-
PWSではうまくいったのに、、、
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
Excelでdatファイルを作成??
-
バッチファイルが作成できない
-
複数のテキストファイルをexcel...
-
テキストファイルの文字色に色...
-
batファイル処理でのテキストフ...
-
複数のファイルを同時検索し、...
-
一気にずばっと複数のメールを...
-
CADでグラフ作成
-
windowsへscp
-
ファイル名の特定文字だけ削除...
-
複数のテキストファイルをexcel...
-
VBSでテキストファイルのタブ区...
-
マクロでメモ帳に貼り付け
-
ExcelVBA テキストファイルから...
-
ヘルプファイルの翻訳
-
VBAからファイルをzip化したい
-
テキストファイルを、ファイル...
-
フリーソフトの「Tree」をご存...
-
インデザインのテキスト流し込み
-
複数のテキストファイルをまと...
おすすめ情報