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

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

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

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

PowerShell

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

Q&A

2回答

10968閲覧

Powershell CSVで特定の文字列を含む文字列を抽出する

ajifly

総合スコア7

CSV

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

PowerShell

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

0グッド

0クリップ

投稿2018/02/09 02:13

powershellでCSV内の特定の文字列を含む文字列を取り出したいです。
実際にはCSV内にフォルダのパスが記述されています。
同じ列に揃っていないためselect-objectで取り出すことができなくて困っております。
全行列を参照して例えば"C:"で始まる文字列をすべて取り出す、といったことを実現したいと考えているのですが、良い方法があればご教授いただけますでしょうか。
よろしくお願いいたします。

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

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

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

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

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

guest

回答2

0

Import-Csv を使ってみては?

Import-Csv コマンドレットの使用

投稿2018/02/09 03:12

Zuishin

総合スコア28660

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

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

0

Select-Objectが使えない、とあることからImport-Csvを試した上で上手くいかなかった、想定して話をします。

1. Excelに頼る

  • Excelがインストールされている
  • CSVファイルがExcelが解釈できる形式

であるなら、ExcelのCOM操作でやる手があります(PowerShellでやる意味が薄いですが)。

以下はVBAの場合のサンプルです。
ExcelのCOM操作は共通なので、VBAの構文をPowerShellで置き換えれば、PowerShellで動きます。

vba

1Dim csvPath As String 2csvPath = "C:\Example.csv" 3 4'csvファイルをExcelのファイルとして開く 5Dim csvBook As Excel.Workbook 6Set csvBook = Excel.Application.Workbooks.Open(csvPath) 7 8'シート取得(CSVなら Worksheet 1枚しか無いはず) 9Dim ws As Excel.Worksheet 10Set ws = csvBook.Worksheets.Item(1) 11 12'`Worksheet.UsedRange.Value()`で 13'値の入っているセル範囲の値を二次元配列を取得してforeach 14Dim v As Variant 15For Each v In ws.UsedRange.Value() 16 '条件判定・出力 17 If v Like "C:*" Then 18 Debug.Print v 19 End If 20Next v 21 22'保存せずに閉じる 23Call csvBook.Close(False)

2. リフレクションで全プロパティを参照する

PowerShellは動的な操作にも強く、以下のように参照するプロパティを動的に指定することができます。

[string]$propName = "Length" @().$propName # => Array.Length => 0

また、Import-Csvコマンドレットで生成されるオブジェクトはPSObjectを拡張しているため、NotePropertyのメンバーを列挙すればCSVの列名がわかります。

$csvData = Import-Csv -Path $csvPath $csvData[0] | Get-Member -MemberType NoteProperty

これらを組み合わせれば全列参照できるかと思います。

投稿2018/02/09 11:41

imihito

総合スコア2166

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

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

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

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問