先日こちらで質問してすごくぴったりなVBA構文を教えていただきました!
で、またもや問題が出てきました。
教えてもらってばかりで申し訳ないのですが、教えてください。
先日いただいた回答は
Sub CSV入力1()
Dim varFileName As Variant
Dim intFree As Integer
Dim strRec As String
Dim strSplit() As String
Dim i As Long, j As Long
Dim maxrow As Long
Dim wrow As Long
varFileName = Application.GetOpenFilename(FileFilter:="CSV〇〇店売上日計(*.csv),*.csv", _
Title:="CSVファイルの選択")
If varFileName = False Then
Exit Sub
End If
maxrow = Cells(Rows.Count, "A").End(xlUp).Row '最終行取得
wrow = maxrow + 1 '書き込み開始行
intFree = FreeFile '空番号を取得
Open varFileName For Input As #intFree 'CSVファィルをオープン
i = 0
Do Until EOF(intFree)
Line Input #intFree, strRec '1行読み込み
i = i + 1
'最初の1~14行はスキップする。15行以降を処理する
If i > 14 Then
strSplit = Split(strRec, ",") 'カンマ区切りで配列へ
For j = 0 To UBound(strSplit)
Cells(wrow, j + 1) = strSplit(j)
Next
wrow = wrow + 1
End If
Loop
Close #intFree
End Sub
毎日送られてくるデータをコツコツ取得する分には十分なのですが、
例えば月曜日のデータを取得するのを忘れて火曜日に取得しようとするとできないようです。
(うちの会社が本社は日曜日が休みですが、営業所は日曜日開いているので、どうしても日曜のデータは月曜に取り込むことになります)
指定したファイルを順番に取得してけるような構文などありましたら教えてもらいたいです。どうぞよろしくお願いいたします。
No.2ベストアンサー
- 回答日時:
こんにちは
No1様の回答にある通りですが・・
ご提示の処理では、最初に対象のCSVファイルを指定するようになっています。
ですので、
・日曜日のファイルを指定して実行
・月曜日のファイルを指定して実行
すれば済む話だと思いますけれど?
それとも、CSVを出力するシステム側が、自動的に古いファイルを削除するような仕組みになっているのでしょうか?
その場合は、VBAの問題ではなく、そのCSVファイルが削除されないようにする工夫が必要になります。(削除されたファイルは読み込むことはできませんので)
具体的には、削除される前に別のフォルダにコピーを作成しておくとか・・
自動化するなら、タスクスケジューラ等を利用するとかでしょうか。
でも、これまでは問題がなかったのでしょうから、この可能性ではなさそうですね・・
もしも、CSVファイル自体は残っているのであれば、前回も回答しましたように、データに日付を付すような仕組みにしておけば、VBA側で照合して「取り込んでいないデータだけを全て取り込む」ようにしておけば、ご質問の内容になるかと思います。
(処理済みであることが識別できればよいので、日付を付さなくとも、処理したCSVファイルはファイル名に「(済}」等を付しておくことでも可能です。)
また、CSVが蓄積されていく想定でよいのなら、毎日実行する必要もなく、集計結果を必要とする時に実行すれば、まとめて追加取得できるようになるでしょう。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) Excel VBAでフォルダ内の全テキストファイルの任意データを取得について 7 2021/12/18 16:00
- Excel(エクセル) VBA Scripting.Dictionary 連想配列 複数参照する方法 2 2021/12/17 01:52
- Visual Basic(VBA) VBAで質問ですが、皆さんはどの様に導き出しているのでしょうか? 6 2022/05/03 21:53
- Visual Basic(VBA) EXCEL VBA シート貼り付け 3 2021/11/15 12:33
- Excel(エクセル) マクロを修正できないものか、統合シートについて 3 2021/12/07 09:26
- Visual Basic(VBA) EXCLE VBA シートクリックしたら該当シートコピー 1 2021/11/11 16:37
- Visual Basic(VBA) いつもお世話になっております、VBAで教えて頂きたいのですが 2 2022/05/05 22:20
- Visual Basic(VBA) エクセルで複数のCSVを取得したい 2 2021/11/11 16:09
- Visual Basic(VBA) 条件をつけて 抽出 7 2021/12/14 14:37
- Excel(エクセル) マクロ作成で困っています。お教え頂けませんか。 1 2021/12/12 17:02
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・【大喜利】【投稿~11/22】このサンタクロースは偽物だと気付いた理由とは?
- ・お風呂の温度、何℃にしてますか?
- ・とっておきの「まかない飯」を教えて下さい!
- ・2024年のうちにやっておきたいこと、ここで宣言しませんか?
- ・いけず言葉しりとり
- ・土曜の昼、学校帰りの昼メシの思い出
- ・忘れられない激○○料理
- ・あなたにとってのゴールデンタイムはいつですか?
- ・とっておきの「夜食」教えて下さい
- ・これまでで一番「情けなかったとき」はいつですか?
- ・プリン+醤油=ウニみたいな組み合わせメニューを教えて!
- ・タイムマシーンがあったら、過去と未来どちらに行く?
- ・遅刻の「言い訳」選手権
- ・好きな和訳タイトルを教えてください
- ・うちのカレーにはこれが入ってる!って食材ありますか?
- ・おすすめのモーニング・朝食メニューを教えて!
- ・「覚え間違い」を教えてください!
- ・とっておきの手土産を教えて
- ・「平成」を感じるもの
- ・秘密基地、どこに作った?
- ・【お題】NEW演歌
- ・カンパ〜イ!←最初の1杯目、なに頼む?
- ・一回も披露したことのない豆知識
- ・これ何て呼びますか
- ・初めて自分の家と他人の家が違う、と意識した時
- ・「これはヤバかったな」という遅刻エピソード
- ・これ何て呼びますか Part2
- ・許せない心理テスト
- ・この人頭いいなと思ったエピソード
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・好きなおでんの具材ドラフト会議しましょう
- ・餃子を食べるとき、何をつけますか?
- ・あなたの「必」の書き順を教えてください
- ・ギリギリ行けるお一人様のライン
- ・10代と話して驚いたこと
- ・大人になっても苦手な食べ物、ありますか?
- ・14歳の自分に衝撃の事実を告げてください
- ・家・車以外で、人生で一番奮発した買い物
- ・人生最悪の忘れ物
- ・あなたの習慣について教えてください!!
- ・都道府県穴埋めゲーム
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
データ解析ソフトRでのファイル...
-
バッチでCSVを処理する時、空の...
-
VBAでcsvファイルを読み込んで...
-
カンマ区切りのCSVファイルから...
-
Excelで作成した単語帳をp-stu...
-
マクロから出力されるcsvのダブ...
-
csvファイル 項目数取得
-
c#でcsvから指定の1行だけを読...
-
【エクセル マクロ】読み込ん...
-
Visual C++によるcsvファイルの...
-
Excelでcsvのフィールドが減る
-
CSV形式での保存時に”文字列...
-
CSVファイルの項目行を削除...
-
PHP.laravelについて
-
csvファイルでの日付設定「yyyy...
-
VBSでソート&ファイル分割
-
VBAでの行削除について
-
ファイルのアクセス回数について
-
エクセルのプロパティーでセキ...
-
エクセルで複数のコメントのサ...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
カンマ区切りのCSVファイルから...
-
バッチでCSVを処理する時、空の...
-
csvファイル 項目数取得
-
マクロから出力されるcsvのダブ...
-
CSV形式での保存時に”文字列...
-
【C#】パス名で無効な文字
-
エクセルVBA 大容量CSVファイル...
-
データ解析ソフトRでのファイル...
-
CSVファイル作成
-
VBAでcsvファイルを読み込んで...
-
複数のcsvファイルをExcelに一...
-
CSVファイルの項目行を削除...
-
csvファイルでの日付設定「yyyy...
-
複数のCSVファイルのAccessテー...
-
csvファイルを列数ごとに分割す...
-
エクセル形式のファイルの読み込み
-
【エクセル マクロ】読み込ん...
-
VBAでCSVファイルのインポート...
-
【ExcelVBA】UTF-8の文字コード...
-
csvファイルのデータの間引きを...
おすすめ情報