以下のようなCSVファイルがあり、これをAccessにインポートしようとしています。
フィールド1 数字7桁
フィールド2 数字2桁
・・・・・
フィールド20 テキスト42桁
・・・
フィールド26 数字13桁
ただ、レコードの中には長すぎるためか途中で改行されてしまっている
レコードがあり、レコードが途中で切れてしまい、続きが次の行に
読み込まれると言う少し困った状態になっています。
(見たところ、フィールド20で切れているようです)
数箇所なら元のCSVを修正してから取り込めばいいのですが、全体が約80万件で、
そのうち200件以上はあるため、手作業でなく何か自動的に直す方法で対処したいと思っています。
(元のCSV自体が読み込みが重いため、手作業は困難です・・)
Accessに取り込むためのいい方法はないでしょうか?
OSはWinXPのSP2、Accessは2003です。
No.4ベストアンサー
- 回答日時:
検索や置換に正規表現を使えるテキストエディタやPerlの処理系が
あれば、対処出来ます。
フィールド1が数値なので、改行直後は数字であるのが正しいはずで
すよね。テキストの途中で手動で改行してしまったような場合は改
行直後が数字ではない可能性が高いので、そのパターンを見つけて
置換してしまいましょう。たとえば(\r)([^0-9])を\2にとかね。
CSVの処理はOffice製品以外を使うのがコツです。
No.3
- 回答日時:
次のような手順はいかがですか?「フィールド20」以外は数字項目であると仮定しています。
1. 次のような空のテーブルAを用意する
一連番号 オートナンバー型
フィールド1 数字7桁
フィールド2 数字2桁
・・・・・
フィールド20 テキスト42桁
・・・
フィールド26 数字13桁
2. テーブルAに1件、ダミーレコードを格納する
3. 次のような空のテーブルBを用意する
一連番号 オートナンバー型
フィールド20 テキスト42桁
・・・
フィールド26 数字13桁
4. テーブルA、テーブルBにCSVファイルをインポートする
5. テーブルAの先頭レコードを削除する
5. 削除クエリを作成してテーブルAから「フィールド1」の内容が「フィールド20」であるレコードを削除する(VarType関数で判断)
6. 削除クエリを作成してテーブルBから「フィールド20」の内容が「フィールド1」であるレコードを削除する(VarType関数で判断)
7. テーブルA、テーブルBを「一連番号」で結合した、テーブルAの更新クエリを作成し、テーブルBの「フィールド20」~「フィールド26」でテーブルAの「フィールド20」~「フィールド26」を更新する
この手順でテーブルAは求めるテーブルになっているはずです
No.2
- 回答日時:
A.量的に手作業で不可能
B.質問にぴったりの操作もない(そんな特殊ニーズ向きの操作ある訳がない)
であればプログラムで処理するしかない。
プログラム組めない?。●投げだが、じゃあ今回限りということで、ご親切なご回答者が現れるのを待つより他ない。
ーー
そこで問題のレコードを見つける方法は、どうしたらよいか考えましたか。それが判らなければプログラムも組めない。
ーー
私の推測では
CSVを文字列に読み込む(通常は1レコード)
Split関数で、その文字列をカンマで分離。分離されて配列に入るが、Uboundで、これで何個に分離したかわかる。
普通は26個。
分割されたものは25個以下(多分質問者の言によると、20個らしい)なら、分断されたと看做す(X)
25以下なら次を1つ読んで継ぎ足す。
ーー
●Xについて質問者は正しいと思うか?
●80万件CSVファイルを例えばLINE INPUTで読んで、辛抱できないくらい長時間かかると思うか(y)
>元のCSV自体が読み込みが重いためー>少し時間はかかるのは当然だが、私には信じられないが。
ともあれ、CSVファイルを読まなきゃプログラムで処理できないのはあたりまえ。
ーー
この2つぐらいについての見解を補足しておいたら。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
【大喜利】【投稿~9/7】 ロボットの住む世界で流行ってる罰ゲームとは?
ロボットの住む世界で流行ってる罰ゲームとは?
-
フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
あなたが普段思っている「これまだ誰も言ってなかったけど共感されるだろうな」というあるあるを教えてください
-
映画のエンドロール観る派?観ない派?
映画が終わった後、すぐに席を立って帰る方もちらほら見かけます。皆さんはエンドロールの最後まで観ていきますか?
-
海外旅行から帰ってきたら、まず何を食べる?
帰国して1番食べたくなるもの、食べたくなるだろうなと思うもの、皆さんはありますか?
-
天使と悪魔選手権
悪魔がこんなささやきをしていたら、天使のあなたはなんと言って止めますか?
-
EXCEL→ACCESSインポートでセル内改行が機能しません・・。
Access(アクセス)
-
ACCESSでの改行コード
その他(データベース)
-
アクセスでのインポート時の改行について
Access(アクセス)
-
-
4
Access2003で特定列の改行コードを削除してCSVへエクスポート
Excel(エクセル)
-
5
Accessでの置換
Access(アクセス)
-
6
ACCESSにエクセルのデータをインポートする際、改行は?
Access(アクセス)
-
7
Chr(13)とChr(10)の違いは?
PowerPoint(パワーポイント)
-
8
Accessのマクロでモジュールを実行させたい。
Access(アクセス)
-
9
アクセス・テーブルの改行についてです。
Access(アクセス)
-
10
アクセスで#エラーを表示させない方法は?
Access(アクセス)
-
11
Accessでテーブル名やクエリ名一覧の抜き出し
Access(アクセス)
-
12
Accessの画面更新を一時的に停止する方法。
その他(データベース)
-
13
アクセスのレポートを印刷すると白紙がでてきます。改ページついて教えてください。
その他(データベース)
-
14
Accessで文字列の長さによって、フィールドの幅を自動で合わせる方法
Excel(エクセル)
-
15
ACCESSでVBAから選択クエリの抽出条件を指定したい
Access(アクセス)
-
16
Accessのレポート上のテキストボックス値を設定したい
その他(データベース)
-
17
Accessのリンク先を相対パスにしたい
その他(データベース)
-
18
SQL文で パラメータが少なすぎます エラー
Access(アクセス)
-
19
アクセスVBAで既に開いているエクセルを閉じたい
Yahoo!ショッピング
-
20
Accessのクエリで、replace関数を使い、データの中にある”をブランクに置き換えたいのですが
Access(アクセス)
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・人生のプチ美学を教えてください!!
- ・10秒目をつむったら…
- ・あなたの習慣について教えてください!!
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・【大喜利】【投稿~9/18】 おとぎ話『桃太郎』の知られざるエピソード
- ・街中で見かけて「グッときた人」の思い出
- ・「一気に最後まで読んだ」本、教えて下さい!
- ・幼稚園時代「何組」でしたか?
- ・激凹みから立ち直る方法
- ・1つだけ過去を変えられるとしたら?
- ・【あるあるbot連動企画】あるあるbotに投稿したけど採用されなかったあるある募集
- ・【あるあるbot連動企画】フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
- ・映画のエンドロール観る派?観ない派?
- ・海外旅行から帰ってきたら、まず何を食べる?
- ・誕生日にもらった意外なもの
- ・天使と悪魔選手権
- ・ちょっと先の未来クイズ第2問
- ・【大喜利】【投稿~9/7】 ロボットの住む世界で流行ってる罰ゲームとは?
- ・推しミネラルウォーターはありますか?
- ・都道府県穴埋めゲーム
- ・この人頭いいなと思ったエピソード
- ・準・究極の選択
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
Access で 特定の文字の個数を...
-
Access2010での、レポートの両...
-
Accessのテーブルのフィールド...
-
アクセスで追加した項目に全て...
-
ACCESS クエリ抽出する際、重複...
-
accessvba 複数条件でFilterを...
-
アクセス2007でオートナン...
-
Accessで、テーブルに入力した...
-
Access クエリの演算フィールド...
-
SQLステートメントのFROM句・・・
-
Access 選択クエリで「テーブ...
-
途中で改行されたCSVをAccessに...
-
更新クエリをリンクデータベー...
-
Access:値が求めたい値の2倍...
-
Accessを開きなおすとテキスト...
-
アクセスのクエリ 1文字以上を...
-
Accessで、1つの項目に複数の...
-
Access作成について(クエリ)
-
Accessのクエリでハイパーリン...
-
日付型のフィールドに空白を入...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
アクセスで追加した項目に全て...
-
Accessで、1つの項目に複数の...
-
Accessのテーブルのフィールド...
-
テキストボックスにクエリ結果...
-
テーブルでメモ型になっている...
-
Accessを開きなおすとテキスト...
-
Accessで、テーブルに入力した...
-
Access で 特定の文字の個数を...
-
Accessのクエリでハイパーリン...
-
access フォームを開くと「パ...
-
Access:値が求めたい値の2倍...
-
accessでの文字列の混ざった連...
-
途中で改行されたCSVをAccessに...
-
アクセスのクエリ 1文字以上を...
-
Accessの電話番号フィールド
-
アクセスのクエリに「PHONETIC...
-
【急】Access 4桁の数字の頭...
-
ACCESSで2つフィールドの日付...
-
アクセス クエリのフィールド...
-
追加クエリで特定フィールドの...
おすすめ情報