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

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

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

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

PowerShell

Windows PowerShellはコマンドラインインターフェースであり、システム管理を含むWindowsタスク自動化のためのスクリプト言語です。

Q&A

2回答

1789閲覧

【PowerShell】カンマ区切りになっている値を文字列分割したい

DD51

総合スコア1

CSV

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

PowerShell

Windows PowerShellはコマンドラインインターフェースであり、システム管理を含むWindowsタスク自動化のためのスクリプト言語です。

0グッド

0クリップ

投稿2023/04/19 02:51

編集2023/04/19 02:54

#実現したいこと
PowerShellを使ってexeで実行した値をCSVにして格納します。
CSVは現在A列にのみ、AAA,bbb(”,” カンマ区切り)というような値が数百行記述されます。これをA列にAAA、B列にbbbに配列した形のCSVにしたいのです。
不定期のexe実施を予定していて取得行数は変動します。

##試したこと
C:\workSpace\抽出.exe -Delimiter "," > C:\workSpace\結果.csv -force

上記で実施した場合はAAA,bbbがA列にのみ記述されます。

うまく配列ができるスクリプトを教えていただけないでしょうか。
よろしくお願いいたします。

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

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

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

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

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

guest

回答2

0

csvにすべての列のヘッダーはありますか?

# あるならばcsvの1行目からヘッダーを取得してcsvファイルを読み込み # .split(",")はヘッダー行のデリミタに変更してください $csv_header = (Get-Content $csv_path -Encoding UTF8)[0].split(",") $csv = Import-Csv -LiteralPath $csv_path -Encoding UTF8 -Delimiter "," -Header $csv_header | Select-Object -skip 1 # ヘッダーがなければ配列でヘッダーを作成してcsvファイルを読み込み $csv_header = @("A", "B") $csv = Import-Csv -LiteralPath $csv_path -Encoding UTF8 -Delimiter "," -Header $csv_header # 最後にcsvをファイルに出力 $csv | Export-Csv -path "output.csv" -Encoding UTF8 -Delimiter ","

csvのヘッダーや中身がどうなっているのかいまいちわかりませんがこれでどうでしょうか?

投稿2023/04/19 13:37

編集2023/04/19 13:44
nuh

総合スコア15

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

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

DD51

2023/04/21 00:03

ご連絡いただきましてありがとうございました(返答が遅くなり申し訳ありませんでした) トライさせていただきます。
guest

0

■結果.csvを分割するサンプルプログラム

PowerShell

1$path = "C:\TEST\結果.csv" 2if ((Test-Path -LiteralPath $path) -eq $True){ 3 $ALL = @() 4 $Text = [System.IO.File]::ReadAllLines($path,[System.Text.Encoding]::Default) # 文字化けの時に変更する文字 ASCII BigEndianUnicode Default Unicode UTF32 UTF7 UTF8 5 foreach ( $a in $Text ){ 6 $DATA = $a.Replace('"','') 7 $L = ($DATA -split ",")[0] 8 $R = ($DATA -split ",")[1] 9 $ALL = $ALL + ($L + "," + $R) 10 } 11 $out = "C:\TEST\NEW.csv" 12 $stream = New-Object System.IO.StreamWriter($out,$False,[System.Text.Encoding]::GetEncoding('Shift_JIS')) 13 foreach ( $a in $ALL ){ $stream.WriteLine($a) } 14 $stream.Close() 15}else{ 16 Write-Host 'ファイルがありません' 17}

■手順■
①Cドライブに TESTフォルダ を作成してください。
②TESTフォルダの中に 結果.csv を置いてください。
③実行するとTESTフォルダの中に NEW.csvを作成します。

※NEW.csvファイルに不具合がございましたら使用しないでください。

※文字化けが発生した場合は、エンコードを変更してください。

※エクセルで開いて変更後に、保存するとエラーになる可能性があります。

※動作するか分かりません。結果.csvが手に入らないのでテストができません。

※抽出.exeの仕様が分からないので、アドバイスができません。ご了承ください。

投稿2023/04/19 10:32

ccc-

総合スコア342

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

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

DD51

2023/04/21 00:01

ご返信ありがとうございます。(ご連絡が遅くなりまして申し訳ありませんでした) さっそく実施してみます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問