Powershellスクリプトを変更して、ANSI-Windows-1252エンコーディングでファイルを書き出すにはどうすればよいですか?

3
K9-Guy 2019-03-20 16:00.

毎日の入力バンクファイルからエラーレコードを削除することで「フィルタリングされた」出力ファイルを生成するバンキングアプリケーションスクリプトがあります(Windows Serverスクリプトを作成して、次のファイルからエラーレコードとそれぞれの前のレコードを削除する方法を参照してください)。結果は新しいファイルに書き込まれます)。「フィルタリングされた」出力ファイルは、システムを更新するために州に送信されます。ちなみに、銀行から受け取った元の入力ファイルは、ファイルエディター(UltraEdit)でUnix 1252(ANSI Latin 1)として表示され、各レコードは改行でのみ終了します。

「クリーン」(エラーなし)と「ダーティ」(4つのエラーを含む)の両方の入力ファイルから生成されたいくつかのテスト出力ファイルを州に送信して、実装前にすべてが良好であることを確認するためにテストしましたが、少しでした出力ファイルはCRLF行末のUTF-16エンコーディングで生成され、入力と現在のフィルタリングされていない出力はWindows-1252でエンコードされているためです。このシステム上の他のすべての出力ファイルは、Windows-1252でエンコードされています。

案の定…州のシステムのエンコーディングが正しくないという知らせが返ってきました。彼らのコメントは次のとおりです。「ファイルはUCS-2リトルエンディアンでエンコードされており、システムで実行するにはANSIに変換する必要がありました。それは予想外でした。

その後、詳細なトランザクションのないファイルは、EFT拒否プログラムを介して実行されます。

正常に処理されたようですが、変換を行う必要がありました。ANSIで送信できますか、それともUCS 2リトルエンディアンで送信する必要がありますか?」

–Encoding“ Windows-1252”と–Encoding windows-1252をout-fileステートメントに追加しようとしましたが、どちらも次のメッセージを返しました。Out-File:パラメーター 'Encoding'の引数を検証できません。引数「Windows-1252」は、ValidateSet属性で指定されたセット「unknown、string、unicode、bigendianunicode、utf8、utf7、utf32、ascii、default、oem」に属していません。セットに含まれている引数を指定してから、コマンドを再試行してください。C:\ EZTRIEVE \ PwrShell \ TEST2_FilterR02.ps1:47 char:57 + ... OutputStrings | Out-File $ OutputFileFiltered -Encoding "Windows-1252" + ~~~~~~~~~~~~~~ + CategoryInfo:InvalidData :( :) [Out-File]、ParameterBindingVal idationException + FullyQualifiedErrorId:ParameterArgumentValidationError、Microsoft。 Power Shell.Commands.OutFileCommand

私はこれについて何日も助けを求めて高くも低くも見えましたが、本当に明確なものはなく、私が見つけたものの大部分は、Windows-1252から別のエンコーディングへの変換に関係していました。昨日、stackoverflowのどこかで、「ANSI」はWindows-1252と同じであるというコメントを見つけましたが、これまでのところ、Windows-1252エンコーディングオプションを出力ファイルステートメントに適切に追加する方法を示すものは見つかりませんでした。 Powershellはそれを受け入れます。キューに追加された次のいくつかに取り組むことができるように、私は本当にこのプロジェクトを完了する必要があります。–Encodingに追加する必要がある、欠落しているサブパラメーターがある可能性がありますか?

これは、Powershell5.1を搭載したWindowsServer 2016Standardを実行している新しいバックアップサーバー上のDollarUniverse(ジョブスケジューラ)でテストされています。私たちの本番システムは、Windows Server 2012R2上でPowershell5.1を使用してDollarUniverseを実行します(はい、十分なアップグレードウィンドウを探しています:-)

私の最後の試みの時点で、私のPowershellスクリプトは次のとおりです。

 [cmdletbinding()]
 Param
 (
     [string] $InputFilePath
 )   

 # Read the text file
 $InputFile = Get-Content $InputFilePath

# Initialize output record counter
$Inrecs = 0 $Outrecs = 0

# Get the time
$Time = Get-Date -Format "MM_dd_yy" # Set up the output file name $OutputFileFiltered = "C:\EZTRIEVE\CFIS\DATA\TEST_CFI_EFT_RETURN_FILTERED"

# Initialize the variable used to hold the output
$OutputStrings = @() # Loop through each line in the file # Check the line ahead for "R02" and add it to the output # or skip it appropriately for ($i = 0; $i -lt $InputFile.Length - 1; $i++) { if ($InputFile[$i + 1] -notmatch "R02") { # The next record does not contain "R02", increment count and add it to the output $Outrecs++
        $OutputStrings += $InputFile[$i] } else { # The next record does contain "R02", skip it $i++
    }
}

# Add the trailer record to the output
$OutputString += $InputFile[$InputFile.Length - 1] # Write the output to a file # $OutputStrings | Out-File $OutputFileFiltered $OutputStrings | Out-File $OutputFileFiltered -Encoding windows-1252 # Display record processing stats: $Filtered = $Outrecs-$i

Write-Host $i Input records processed Write-Host $Filtered  Error records filtered out

Write-Host $Outrecs  Output records written

1 answers

6
mklement0 2019-03-20 23:59.

注意:

  • 後で、LF(Unixスタイル)改行が必要であることを明確にしました。下部のセクションを参照してください。

  • 次のセクションでは、最初に尋ねられた質問を扱い、CRLF(Windowsスタイル)改行を含むファイルを作成するソリューションを示します(Windowsで実行した場合)。


場合は、あなたのシステムのUnicode対応でないプログラムの言語設定(別名システムロケールは)持っていることを起こるのWindows-1252アクティブANSIコードページとして、(米国英語または西ヨーロッパのシステムでは、例えば)の使用-Encoding Default、ためDefaultのそのコード・ページを参照Windows PowerShellの(しかしないPowerShellのコアをサポートしていませんBOMレスUTF-8にデフォルト設定と、Defaultエンコードの識別子)。

確認方法: [cultureinfo]::CurrentCulture.TextInfo.ANSICodePage -eq 1252

... | Out-File -Encoding Default $file

注意:

  • 場合あなたが特定されているデータが実際にASCII範囲の文字(除外のような文字がアクセント付き7ビットの範囲、内のコードポイントを持つ文字で独占的に構成されていることü)、-Encoding Defaultお使いのシステムロケールは、ANSIコードページ使用している場合でも動作する他のよりをすべての(シングルバイト)ANSIコードページが7ビットサブレンジのすべてのASCII文字を共有している場合、Windows-1252。次に、を使用することもできますが、-Encoding ASCII結局のところ非ASCII文字が存在する場合、それらはリテラル?文字に音訳され、情報が失われることに注意してください。

  • Set-Contentコマンドレットは、実際にデフォルトDefaultWindows PowerShellの(ただしPowerShellでエンコーディングコア一貫したデフォルトはBOMなしUTF-8です、)。

  • しばらくSet-Contentのそれからの文字列化の挙動が異なるOut-File-この回答を参照してください-ファイルへの書き込みにオブジェクトがすでにあれば、それは実際にはより良い選択だある文字列が。


それ以外の場合は、2つのオプションがあります。

  • .NETFrameworkファイルのI / O機能を直接使用します。ここでは、.NETでサポートされている任意のエンコーディングを使用できます。例えば:

    $lines = ...  # array of strings (to become lines in a file)
    # CAVEAT: Be sure to specify an *absolute file path* in $file, # because .NET typically has a different working dir. [IO.File]::WriteAllLines($file, $lines, [Text.Encoding]::GetEncoding(1252))
    
  • 使用PowerShellのコアあなたがサポートされている任意の.NETエンコーディングを渡すことができます、
    -Encodingパラメータ:

    ... | Out-File -Encoding ([Text.Encoding]::GetEncoding(1252)) $file
    

PSv5.1 +では、この回答で詳しく説明されているように、>および>>演算子使用されるエンコーディングを実際に変更できることに注意してください。ただし、Windows PowerShellでは、のパラメータでサポートされているエンコーディングに制限されています。
Out-File-Encoding


WindowsでLF(Unixスタイル)改行を使用してテキストファイルを作成する:

PowerShell(常に)と.NET(デフォルト)は、[Environment]::NewLine文字列を行としてファイルに書き込むときに、プラットフォームに適した改行シーケンスを使用します。言い換えると、WindowsではCRLF改行を含むファイルになり、Unixライクなプラットフォーム(PowerShell Core)ではLF改行を含むことになります。

以下のソリューションは、ファイルに書き込むデータが、たとえばによって返されるように、書き込む行を表す文字列の配列であると想定していることに注意してくださいGet-Content(結果の配列要素は、末尾の改行シーケンスのない入力ファイルの行です)。

Windows(PSv5 +)でLF改行を含むファイルを明示的に作成するには:

$lines = ... # array of strings (to become lines in a file) ($lines -join "`n") + "`n" | Set-Content -NoNewline $file

"`n" LF文字を生成します。

注意:

  • Windows PowerShellでは、これはアクティブなANSIコードページのエンコーディングを暗黙的に使用します。

  • PowerShell Coreでは、これにより、BOMなしでUTF-8ファイルが暗黙的に作成されます。代わりにアクティブなANSIコードページを使用する場合は、次を使用します。

    -Encoding ([Text.Encoding]::GetEncoding([cultureinfo]::CurrentCulture.TextInfo.ANSICodePage))
    

PSv4-(PowerShellのバージョン4以下)、あなたは直接の.NET Frameworkを使用する必要があります:

$lines = ...  # array of strings (to become lines in a file)


# CAVEAT: Be sure to specify an *absolute file path* in $file, # because .NET typically has a different working dir. [IO.File]::WriteAllText($file, ($lines -join "`n") + "`n")

注意:

  • WindowsPowerShellとPowerShellCoreの両方で、これによりBOMなしのUTF-8ファイルが作成されます。

  • 代わりにアクティブなANSIコードページを使用する場合は[Text.Encoding]::GetEncoding([cultureinfo]::CurrentCulture.TextInfo.ANSICodePage)、追加の引数としてに渡しますWriteAllText()

Related questions

MORE COOL STUFF

ケイト・ブランシェットは3日間一緒に夫と一緒に寝て、25年経ってもまだ夫と結婚しています

ケイト・ブランシェットは3日間一緒に夫と一緒に寝て、25年経ってもまだ夫と結婚しています

ケイト・ブランシェットは、夫に会ったとき、典型的な交際のアドバイスに逆らいました。

マイケルシーンが非営利の俳優である理由

マイケルシーンが非営利の俳優である理由

マイケルシーンは非営利の俳優ですが、それは正確にはどういう意味ですか?

ホールマークスターのコリンエッグレスフィールドがRomaDramaLiveでスリル満点のファンと出会う![エクスクルーシブ]

ホールマークスターのコリンエッグレスフィールドがRomaDramaLiveでスリル満点のファンと出会う![エクスクルーシブ]

特徴的なスターのコリン・エッグレスフィールドは、RomaDrama Liveでのスリル満点のファンとの出会いについて料理しました!加えて、大会での彼のINSPIREプログラム。

「たどりつけば」をオンラインでストリーミングできない理由

「たどりつけば」をオンラインでストリーミングできない理由

ノーザンエクスポージャーが90年代の最も人気のある番組の1つになった理由を確認するには、Blu-rayまたはDVDプレーヤーをほこりで払う必要があります。

バイオニック読書はあなたをより速く読むことができますか?

バイオニック読書はあなたをより速く読むことができますか?

BionicReadingアプリの人気が爆発的に高まっています。しかし、それは本当にあなたを速読術にすることができますか?

ドミニカのボイリング湖:アクセスは簡単ではありませんが、ハイキングする価値があります

ドミニカのボイリング湖:アクセスは簡単ではありませんが、ハイキングする価値があります

ドミニカのボイリング湖は、世界で2番目に大きいボイリング湖です。そこにたどり着くまでのトレッキングは大変で長いですが、努力する価値は十分にあります。

私たちの水をきれいに保つのを助けるためにあなたの髪を寄付してください

私たちの水をきれいに保つのを助けるためにあなたの髪を寄付してください

サロンからのヘアトリミングや個人的な寄付は、油流出を吸収して環境を保護するのに役立つマットとして再利用できます。

ホワイトハウスの最も記憶に残る結婚式を見てください

ホワイトハウスの最も記憶に残る結婚式を見てください

過去200年以上の間にホワイトハウスで結婚したのはほんの数人です。彼らは誰でしたか、そしてそこで結婚式を獲得するために何が必要ですか?

今週のコミックコンですべての素晴らしいものに追いつく方法

今週のコミックコンですべての素晴らしいものに追いつく方法

サンディエゴコミックコンは今週開幕し、オタクのアナウンス、ポスター、予告編、お気に入りの番組や映画のからかいでいっぱいになります。SDCCは、コンベンションフロア全体の多くのパネルで行われているため、すべてに対応するのは難しい場合があります。

Googleの9千万ドルの和解はアプリ開発者にとってもGoogleにとっても勝利ですか?

Googleの9千万ドルの和解はアプリ開発者にとってもGoogleにとっても勝利ですか?

小さなアプリ開発者は金曜日に発表された法的な和解でグーグルから9千万ドルをこじ開けた。アップルとの同様の合意に続いて熱くなった。金曜日のブログ投稿で、Googleは、Androidメーカーが市場での優位性を悪用してPlayストア経由でのアプリ内購入に対して30%の料金を不当に請求したと主張するアプリ開発者との訴訟を解決するために、9千万ドルを支払うことに合意したと述べました。

RadioShackのTwitterはハッキングされていませんでした、それはただの暗号のサクラです

RadioShackのTwitterはハッキングされていませんでした、それはただの暗号のサクラです

今週、RadioShackのTwitterアカウントは、奇妙なものから完全にひどいものになりました。短い順序で、会社のフィード全体が、バイブレーター、「ビッグティット」(スペルミス)、有名人やその他の企業アカウントを荒らしているツイートなど、NSFW素材の真の山になりました。

ヒッグス粒子から10年後、物理学にとって次の大きなものは何ですか?

ヒッグス粒子から10年後、物理学にとって次の大きなものは何ですか?

大型ハドロン衝突型加速器のトンネル内にあるコンパクトミュオンソレノイド(CMS)検出器。2012年7月4日、CERNの科学者たちは、1960年代に最初に提案された素粒子であるヒッグス粒子の観測を確認しました。

Zendaya Wishes Boyfriend Tom Holland Happy Birthday with Cuddly Photo: He 'Makes Me the Happiest'

Zendaya Wishes Boyfriend Tom Holland Happy Birthday with Cuddly Photo: He 'Makes Me the Happiest'

Zendaya shared a sweet photo in honor of boyfriend Tom Holland's 26th birthday Wednesday

小さな女性:脳卒中を患った後に病院から解放されたアトランタのジューシーな赤ちゃん:「まだ癒し」

小さな女性:脳卒中を患った後に病院から解放されたアトランタのジューシーな赤ちゃん:「まだ癒し」

シーレン「Ms.JuicyBaby」ピアソンは、先月脳卒中で入院した後、「もう一度たくさんのことをする方法を学ばなければならない」ため、言語療法を受けていることを明らかにしました。

エマストーンは彼女のクリフサイドマリブビーチハウスを420万ドルでリストアップしています—中を見てください!

エマストーンは彼女のクリフサイドマリブビーチハウスを420万ドルでリストアップしています—中を見てください!

オスカー受賞者の世紀半ばの家には、3つのベッドルーム、2つのバス、オーシャンフロントの景色があります。

ジーニー・メイ・ジェンキンスは、母乳育児の経験の中で、彼女は「本当に、本当に落ち込んでいる」と言います

ジーニー・メイ・ジェンキンスは、母乳育児の経験の中で、彼女は「本当に、本当に落ち込んでいる」と言います

ジーニー・メイ・ジェンキンスは、生後4か月の娘、モナコに母乳育児をしていると語った。

Un breve viaje espacial sobre conceptualizar el diseño

Complicarse la vida, mezclar churros con meninas (nada de ovejas) y encontrar valor en un trastero que adquiriste en una puja.

Un breve viaje espacial sobre conceptualizar el diseño

Bien. Hay un momento en toda salida al espacio exterior en el que de la tensión, la velocidad y las altas temperaturas derivadas del cruce de estratosfera a ionosfera se pasa a un momento de súbita calma, donde se despliega la vista completa del paisaje espacial que nos rodea.

Seguindo Todos os Protocolos (2022), de Fábio Leal

Seguindo Todos os Protocolos (2022), de Fábio Leal

Chico quer transar. Até aí, tudo bem.

多元宇宙—Junø

多元宇宙—Junø

チェーン間アカウントがJunoに登場します。異なるブロックチェーン間でスマートコントラクトの構成可能性と真の相互運用性を提供します。

#brand【ベター・コール・ソール!アメリカのテレビシリーズ「ブレイキング・バッド」に最高のビジネス例が隠されている】・・・ルールクリエイティブ

#brand【ベター・コール・ソール!アメリカのテレビシリーズ「ブレイキング・バッド」に最高のビジネス例が隠されている】・・・ルールクリエイティブ

1.ドラマを見た後、起業する考えはありますか?あなたのビジネスはボトルネックに遭遇しましたか?方向性がなくてわからない場合は、ドラマを追いかけて行くことを心からお勧めします。(?)ブラフではなく、最も完璧なビジネス例を隠すドラマがあります。2.ブレイキング・バッドとその弁護士ドラマ「ブレイキング・バッド」を見た友人たちは、演劇の中で、穏やかな表情で、弁護士のソウル・グッドマンに深く感銘を受けなければなりません。口を開けて、感覚の弱い傭兵の性格を持っています。道徳の面で、サル・グッドマンは無意識のうちに劇に欠かせない役割を果たし、彼自身のシリーズ「絶望的な弁護士」(ベター・コール・ソール)を生み出しました。ウェントウのテキストとビデオは、劇中のソウル・グッドマンのテレビコマーシャルです。製品(サービス)、競争戦略、市場ポジショニング、ブランド名、ターゲット顧客グループ、コミュニケーション軸から広告まで、サル・グッドマンの役割のビジネス設定は、「最低」と見なすことができる超超超超超超完全です。ブランドコミュニケーションのコスト」「変化」のモデル。なぜ?私の分析をご覧ください。3.ソウル・グッドマンの「事業戦略」1.基本情報ブランド名:Saul Goodman製品:法律相談サービス対象顧客:麻薬中毒、飲酒運転、事故など。法律知識の欠如は、一般的に公立弁護士にしか余裕がなく、真面目な弁護士も「特別な法律を持つ消費者」を避けます。恐れてはいけない「​​ニーズ」。コミュニケーションの主軸:この国のすべての男性、女性、子供は有罪判決を受けるまで無実だと思います。地域:アルバカーキ市スローガン:Thrallに電話したほうがいいです!(ベター・コール・ソール)広告:2つの可能性のある犯罪状況をシミュレートします+サウルの主張+サウルのスローガン2をより適切に呼び出します。

Language