ExcelのシートにCSVを読み込むVBAを作りました。
しかし、
P列~U列は、4桁の数字として取り込みたいのですが、
0004 → 4
0700 → 700 の様に、先頭の0が削除されてしまいます。
取り込み方はいくつかあると思いますが、
取り込んだ後、P列~U列を"0000"の様に4桁指定の書式に変える場合どうしたら良いでしょうか?
表示形式だけ0000の形式にするのではなく、セル内に文字列として「0001」と入るようにしたいです。
よろしくお願いいたします。
A 回答 (6件)
- 最新から表示
- 回答順に表示
No.5
- 回答日時:
No2です。
CSVファイルをシートへ直接読み込む方法です。
ファイル名はD:\goo\data\Book1.csvになっているので、あなたの環境に合わせてください。
A列~O列は標準形式
P列~U列は文字列形式で読み込みます。
Sub CSV読み込み()
Dim finfo As Variant
Dim ws As Worksheet
Set ws = ActiveSheet ' CSV のデータを取り込むシート
Dim fc As Variant
Dim i As Long
fc = Array()
'A~O列は標準形式
For i = 0 To 14
ReDim Preserve fc(i)
fc(i) = xlGeneralFormat
Next
'P~U列は文字列形式
For i = 15 To 20
ReDim Preserve fc(i)
fc(i) = xlTextFormat
Next
Dim qt As QueryTable
Set qt = ws.QueryTables.Add(Connection:="TEXT;D:\goo\data\Book1.csv", Destination:=ws.Range("A1")) ' CSV を開く
With qt
.TextFileColumnDataTypes = fc
.TextFilePlatform = 932 ' 文字コードを指定
.TextFileParseType = xlDelimited ' 区切り文字の形式
.TextFileCommaDelimiter = True ' カンマ区切り
.RefreshStyle = xlOverwriteCells ' セルに上書き
.Refresh ' データを表示
.Delete ' CSV との接続を解除
End With
MsgBox ("OK")
End Sub
ありがとうございます。
CSVをExcel上に展開するのではなくて、形式を指定しながら取り込む方式ですね。
今までの悩みが何だっていうくらい期待通りの結果が得られました。
分かりやすいソースなのでカスタマイズもし易かったです。
CSVを開くのは決められたファイルではなく都度選択できるようにしました。
No.4
- 回答日時:
マクロ音痴の私自身は下記の手順で対処しています。
[データ]⇒[データの取得と変換 <テキストまたはCSVから>]⇒表示された[データの取り込み]メニューから目的のCSVファイルを選択⇒[インポート]をパシーッ
を実行した結果を添付図の下端に示しました。
後はその画面の Column2、Column4 のデータの左端に 0 を付加する作業をすれば好い。
さて、どうやるかはご自分で勉強なさってください。
【独白】Excelワークシート⇒CSVファイルへのいわゆる[エクスポート]機能を装備したのはMS社の“小さな親切”ですが、逆のCSVファイルからのインポート機能の充実を長年オザナリのまま改善しないのは、MS社の“大きな怠慢”だと思います、ハイ。
No.3
- 回答日時:
項目の型を指定
Dim fi As Variant
fi = Array(Array(1, xlTextFormat), _
Array(2, xlGeneralFormat), _
Array(3, xlYMDFormat))
Call Workbooks.OpenText("D:\hoge.csv", Origin:=xxx, FieldInfo:=fi) ' 文字列、数値、日付の順に読み込む
ありがとうございます。
重要なヒントと認識してます。
ただ、既存のソースにうまく組み込む程のスキルがないため、
後の回答のソースを使わせて頂きました。
No.2
- 回答日時:
CSVのデータが4桁の数字なら、
取り込む前にP~Uの書式を文字列に変えてはいかがでしょうか。
Columns("P:U").NumberFormatLocal = "@"
を実行後、P~Uのセルにデータを設定すればよろしいかと。
アドバイス感謝します。
ただ、お恥ずかしいことにcsv取り込みが良く分からないため、
具体的な処理としては、csvをopenしてから全範囲を
コピー→貼り付けしてるので、
openした段階で 0 落ちを起こしてると思うのです。
その処理が分からないため、貼った後の事後処理をしてる次第です。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Access(アクセス) CSVファイルの「0落ち」にVBA 6 2023/02/02 15:27
- Visual Basic(VBA) Excel VBA 書式変更で困ってます。 オートフィルターの日付フィルターを用いて データの絞り込 2 2022/07/26 22:16
- Excel(エクセル) csvファイルをExcel形式で読み込むには 2 2023/07/03 13:09
- Excel(エクセル) PowerQueryに詳しい方教えてください(Office365) 1 2022/07/24 21:11
- Excel(エクセル) csvに別のExcelの文章を差し込む 2 2023/04/01 16:06
- Excel(エクセル) エクセルのVBAについて とあるサイトのコードを参考に、CSVの文字化けを直すVBAを作成しているの 7 2022/11/04 14:15
- その他(Microsoft Office) wordの差し込み印刷での日付表示 2 2023/08/15 16:51
- Excel(エクセル) エクセルにおいてセル内の文字を出来るだけ大きく表示する方法を教えてください。 4 2022/07/30 08:08
- Visual Basic(VBA) 3つのプロシージャをまとめたら実行時エラー発生で対応不能 6 2022/05/17 01:47
- システム CSVファイルのマッピング処理の省力化 1 2022/11/24 00:01
このQ&Aを見た人はこんなQ&Aも見ています
-
とっておきの「夜食」教えて下さい
真夜中に小腹がすいたときにこっそり作るメニュー、こっそり家を抜け出して食べに行くお店… 人には言えない、けど自慢したい、そんなあなたの「とっておきの夜食」を教えて下さい。
-
あなたにとってのゴールデンタイムはいつですか?
一週間の中でもっともテンションが上がる「ゴールデンタイム」はいつですか? その逆で、一週間でもっとも落ち込むタイミングでも構いません。 よかったら教えて下さい!
-
遅刻の「言い訳」選手権
よく遅刻してしまうんです…… 「電車が遅延してしまい遅れました」 「歯医者さんが長引いて、、、」 「病院が混んでいて」 などなどみなさんがこれまで使ってきた遅刻の言い訳がたくさんあるのではないでしょうか?
-
牛、豚、鶏、どれか一つ食べられなくなるとしたら?
牛肉、豚肉、鶏肉のうち、どれか一種類をこの先一生食べられなくなるとしたらどれを我慢しますか?
-
好きな和訳タイトルを教えてください
洋書・洋画の素敵な和訳タイトルをたくさん知りたいです!【例】 『Wuthering Heights』→『嵐が丘』
-
エクセルvbaで転記したのですが、数字のゼロが消えてしまいます。 ゼロも転記するためにはどうしたらい
Excel(エクセル)
-
【Excel VBA】先頭の「0」飛びを埋める方法
Visual Basic(VBA)
-
EXCELVBAにて文字列にして「01」と表示させて、CSV形式で保存すると「1」になってしまう。
その他(プログラミング・Web制作)
-
-
4
CSVファイルの「0落ち」にVBA
Access(アクセス)
-
5
VBAで保存しないで閉じると空のBookが残る
Excel(エクセル)
-
6
VBA 数値を文字列として貼付したい
Excel(エクセル)
-
7
VBA 先頭文字の0(ゼロ)を省略しないでコピー
Access(アクセス)
-
8
【ExcelVBA】各セルをダブルクォーテーションで括ってCSV保存したい
Visual Basic(VBA)
-
9
エクセル:マクロ「Application.CutCopyMode = False」って?
Excel(エクセル)
-
10
VBAマクロ実行時エラーの修正について
Visual Basic(VBA)
-
11
EXCELからCSVへ変換すると0が消えてしまいます
Excel(エクセル)
-
12
Excel VBAでCSVファイルを読込むと何故か文字列が日付に変換さ
その他(Microsoft Office)
-
13
VBAでエクセルシートを更新(リフレッシュ)する方法を教えて下さい。
Excel(エクセル)
-
14
エクセルのエラーメッセージ「400」って?
Visual Basic(VBA)
-
15
VBAを使って選択した範囲の数字(電話番号)の先頭に0を付ける方法が知りたいです。
Visual Basic(VBA)
-
16
Excelで数値→文字列変換で指数表示になったものをいっぺんに直したい
Excel(エクセル)
-
17
VBAで文字列を数値に変換したい
Excel(エクセル)
-
18
VBAでブックを非表示で開いて処理して閉じる方法
Excel(エクセル)
-
19
複数の条件に合う行番号を取得するには
その他(Microsoft Office)
-
20
エクセルVBAで5行目からオートフィルタモードに設定したいたい
Excel(エクセル)
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・【大喜利】【投稿~11/22】このサンタクロースは偽物だと気付いた理由とは?
- ・お風呂の温度、何℃にしてますか?
- ・とっておきの「まかない飯」を教えて下さい!
- ・2024年のうちにやっておきたいこと、ここで宣言しませんか?
- ・いけず言葉しりとり
- ・土曜の昼、学校帰りの昼メシの思い出
- ・忘れられない激○○料理
- ・あなたにとってのゴールデンタイムはいつですか?
- ・とっておきの「夜食」教えて下さい
- ・これまでで一番「情けなかったとき」はいつですか?
- ・プリン+醤油=ウニみたいな組み合わせメニューを教えて!
- ・タイムマシーンがあったら、過去と未来どちらに行く?
- ・遅刻の「言い訳」選手権
- ・好きな和訳タイトルを教えてください
- ・うちのカレーにはこれが入ってる!って食材ありますか?
- ・おすすめのモーニング・朝食メニューを教えて!
- ・「覚え間違い」を教えてください!
- ・とっておきの手土産を教えて
- ・「平成」を感じるもの
- ・秘密基地、どこに作った?
- ・【お題】NEW演歌
- ・カンパ〜イ!←最初の1杯目、なに頼む?
- ・一回も披露したことのない豆知識
- ・これ何て呼びますか
- ・初めて自分の家と他人の家が違う、と意識した時
- ・「これはヤバかったな」という遅刻エピソード
- ・これ何て呼びますか Part2
- ・許せない心理テスト
- ・この人頭いいなと思ったエピソード
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・好きなおでんの具材ドラフト会議しましょう
- ・餃子を食べるとき、何をつけますか?
- ・あなたの「必」の書き順を教えてください
- ・ギリギリ行けるお一人様のライン
- ・10代と話して驚いたこと
- ・大人になっても苦手な食べ物、ありますか?
- ・14歳の自分に衝撃の事実を告げてください
- ・家・車以外で、人生で一番奮発した買い物
- ・人生最悪の忘れ物
- ・あなたの習慣について教えてください!!
- ・都道府県穴埋めゲーム
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
Word2016でExcelデータを差込し...
-
【Excel VBA】CSV取込時、数字...
-
Excel 表の必要箇所だけを抜き...
-
EXCELの列の幅
-
EXCEL2007で2つのシートのどっ...
-
EXCELで2つのシートから一致し...
-
エクセルで前年同日・前月同日...
-
excelの列がいっぱいになり列を...
-
VBAで他のシートの特定の列を検...
-
エクセルで縦線のいっぱい入っ...
-
SUMPRODUCT関数で複数条件適用...
-
ピボットテーブル作成後、重複...
-
ExcelのIF関数について
-
順位表において先週と今週の数...
-
エクセルでページ毎の計をつけ...
-
(形式直し)Sheetの表のサイズ...
-
Excelで奇数行を削除
-
セル入力文字が、「右のセルに...
-
パワポの複数ページにまたがる...
-
エクセル、ページをまたがった...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
Word2016でExcelデータを差込し...
-
【Excel VBA】CSV取込時、数字...
-
EXCELの列の幅
-
エクセルで前年同日・前月同日...
-
エクセルでページ毎の計をつけ...
-
EXCEL2007で2つのシートのどっ...
-
excelの列がいっぱいになり列を...
-
Excel 表の必要箇所だけを抜き...
-
EXCELで2つのシートから一致し...
-
エクセルで電話番号にハイフン...
-
選択範囲の表を空白を削除して...
-
エクセル:最新データ12件で...
-
エクセルVBAで複数列データを1...
-
エクセルの余白を0にしても列...
-
ピボットテーブル作成後、重複...
-
Excelで奇数行を削除
-
エクセルで縦線のいっぱい入っ...
-
EXCELで不良率を出そうと思って...
-
SUMPRODUCT関数で複数条件適用...
-
マクロ VBA 他のブックのデータ...
おすすめ情報