data:image/s3,"s3://crabby-images/8b4aa/8b4aa999d801fa45f105bd7a2507596a0106b08c" alt=""
VBAで
・テキストファイルをソートして、重複行を削除
できます!
data:image/s3,"s3://crabby-images/8b4aa/8b4aa999d801fa45f105bd7a2507596a0106b08c" alt=""
VBAから
・Power Shellのコマンドレットを実行
することで実現します!
VBAコード
ここでは例として
・デスクトップ配下のテキストファイル「sample.txt」をソートして、重複行を削除
します。
data:image/s3,"s3://crabby-images/55d00/55d001a68647374415eeb804258855b8ced36605" alt="テキストファイル「sample.txt」"
data:image/s3,"s3://crabby-images/3b74e/3b74eaed19f4a25f477baf97f9ae8f8ae655e10d" alt="テキストファイル「sample.txt」の内容(ソートされていない、かつ重複行あり)"
Option Explicit
Sub sample()
Dim targetFile As String
Dim psCommand As String
Dim wsh As Object
Dim result As Integer
'対象ファイル
targetFile = "C:\Users\user\Desktop\sample.txt"
'PowerShellのコマンドレットを組み立て
psCommand = "powershell -NoProfile -ExecutionPolicy Unrestricted "
psCommand = psCommand & "(Get-Content " & targetFile & ") | Sort-Object -Unique "
psCommand = psCommand & "| Out-File -Encoding default " & targetFile
Set wsh = CreateObject("WScript.Shell")
'PowerShellのコマンドレットを実行
result = wsh.Run(Command:=psCommand, WindowStyle:=0, WaitOnReturn:=True)
If (result = 0) Then
MsgBox ("ソート(重複削除含む)が正常終了しました。")
Else
MsgBox ("ソート(重複削除含む)が異常終了しました。")
End If
'後片付け
Set wsh = Nothing
End Sub
実行結果
テキストファイルをソートして、重複行を削除できました。
data:image/s3,"s3://crabby-images/f3aa6/f3aa61d1d8d4932237d30b82c70207f7c18ff87a" alt="実行結果①"
data:image/s3,"s3://crabby-images/20b2c/20b2c051139f442406adeb32f5048708d8c8ba75" alt="実行結果②"
参考①
上記のVBAコードは以下の記事を参考にして作成しました。
参考②
上記で使用した以下の詳細は、公式サイトをご確認ください。
●Power Shellのコマンドレット「Get-Content」
●Power Shellのコマンドレット「Sort-Object」
●Power Shellのコマンドレット「Out-File」