質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
CSV

CSV(Comma-Separated Values)はコンマで区切られた明白なテキスト値のリストです。もしくは、そのフォーマットでひとつ以上のリストを含むファイルを指します。

VBA

VBAはオブジェクト指向プログラミング言語のひとつで、マクロを作成によりExcelなどのOffice業務を自動化することができます。

オブジェクト

オブジェクト指向において、データとメソッドの集合をオブジェクト(Object)と呼びます。

マクロ

定義された処理手続きに応じて、どのような一連の処理を行うのかを特定させるルールをマクロと呼びます。

Q&A

解決済

3回答

714閲覧

VBAでのシート作成

uimaro

総合スコア14

CSV

CSV(Comma-Separated Values)はコンマで区切られた明白なテキスト値のリストです。もしくは、そのフォーマットでひとつ以上のリストを含むファイルを指します。

VBA

VBAはオブジェクト指向プログラミング言語のひとつで、マクロを作成によりExcelなどのOffice業務を自動化することができます。

オブジェクト

オブジェクト指向において、データとメソッドの集合をオブジェクト(Object)と呼びます。

マクロ

定義された処理手続きに応じて、どのような一連の処理を行うのかを特定させるルールをマクロと呼びます。

0グッド

0クリップ

投稿2020/10/08 08:56

VBAでテキストファイルを開いてCSVに変換するというプログラムを書いています。
まだ途中ですが、
新規シートを作成する際に、
Worksheet.Add After:=Worksheets(Worksheets.Count).Name = sheet_name
のところで、「オブジェクトが必要です」とのエラーが出てしまいます。
対応策のご教示をいただきたいです。

型の指定の仕方に問題があるのでしょうか?

VBA

1コード

Private Sub DataConvertion_Click()

Dim buf As String, cnt As Long Dim file_add As String Dim path As String, n As Long, i As Long Dim file_path As String file_add = Cells(3, 4).Value path = file_add & "\" buf = Dir(path & "*.txt") file_path = file_add & "\" & buf Do While file_path <> "" cnt = cnt + 1 Cells(cnt, 1) = buf Dim sheet_name As String sheet_name = Left(buf, 14) Worksheet.Add After:=Worksheets(Worksheets.Count).Name = sheet_name 'データをCSV化 Open file_path For Input As #1 Do Until EOF(1) Line Input #1, file_path n = n + 1 Cells(n, 1) = file_path Loop Close #1 buf = Dir() Loop

End Sub

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答3

0

Sub テキスト取り出し()

Dim buf As String, cnt As Long
Dim file_add As String
Dim path As String, n As Long, i As Long
Dim file_path As String
Dim sheet_name As String
Dim a As String
Dim ba As String '読み込み用

On Error GoTo myerror a = ActiveSheet.Name file_add = Cells(3, 4).Value path = file_add & "\" buf = Dir(path & "*.txt") file_path = file_add & "\" & buf Do While file_path <> "" 'ファイル名が有る限り cnt = cnt + 1 'セルカウンター Worksheets(a).Cells(cnt, 1) = buf 'シート名を印字 sheet_name = Left(buf, 14) 'Txtファイル名 Sheets.Add After:=Sheets(Sheets.Count) Sheets(Sheets.Count).Name = sheet_name '追加最終右側シートへ名前 'データをCSV化 Open path & buf For Input As #1 Do Until EOF(1) Line Input #1, ba n = n + 1 Cells(n, 1) = ba Loop n = 0 Close #1 buf = Dir() Loop

myerror:

End Sub

投稿2020/10/11 09:52

syousuke.33

総合スコア312

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

sheet_name As String
sheet_name = Left(buf, 14)
Sheets.Add After:=ActiveSheet
Sheets(Sheets.Count).Name = sheet_name
'データをCSV化

投稿2020/10/09 00:48

syousuke.33

総合スコア312

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

hatena19

2020/10/09 01:02

そのコードだと、アクティブなシートの右に新規シートを挿入後、最右端のシートの名前を変更するという処理になりますね。アクティブシートが最右端のシートならいいですが、そうでないとまずいですよね。 最右端にシートを追加するというのが質問者さんの希望と思われますので、下記になると思います。 sheet_name As String sheet_name = Left(buf, 14) Sheets.Add After:=Sheets(Sheets.Count) Sheets(Sheets.Count).Name = sheet_name
syousuke.33

2020/10/11 09:52

hatena19様 指摘していただき ありがとうございました。 質問者のuimaro様のアクションが何もないけど理解されたのでしょうか? テキストファイル4枚作って テストしてみましたが又エラーが出ました。 「ファイル名または番号が不明です」表示された。 Open file_path For Input As #1  ここで黄色ラインになっていた file_pathにカーソルを置くとシートパスでなく、テキストの文字列が 表示されていた。解決に時間かかった 参考までに構文を記載しました。 シート最終右側に余計なシートが表示された!
uimaro

2020/10/13 05:40

返答が遅くなりすみません。 下記の様に、別のシートをコピーする方法にしたらエラーは出なくなりました。 Call Worksheets("FORMAT").Copy(After:=Worksheets(Worksheets.Count)) 結局根本的な部分とは少し違った形での解決となりましたが、ご協力いただきありがとうございました。
guest

0

ベストアンサー

diff

1- Worksheet.Add After:=Worksheets(Worksheets.Count).Name = sheet_name 2+ Worksheets.Add(After:=Worksheets(Worksheets.Count)).Name = sheet_name

上記の修正でいいのですが、追加と名前変更を1行で記述するのは読みづらいので、下記のように分けた方が分かり安いかもしれません。

vba

1 Worksheets.Add After:=Worksheets(Worksheets.Count) 2 ActiveSheet.Name = sheet_name

投稿2020/10/08 10:31

編集2020/10/09 02:55
hatena19

総合スコア34075

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問