首页 > 解决方案 > 在Powershell中将制表符分隔的文本转换为没有CR的CSV

问题描述

使用以下 powershell 命令将制表符分隔的文本转换为 CSV。

Import-Csv inbound.txt -Delimiter `t | Export-Csv inbound.csv -NoTypeInformation 

一切顺利,文件被转换为 CSV,并在每个字段周围加上引号。但是,生成的文件在每行的最后一个引号内有一个 CR,扭曲了最后一列(数量)的值.. 例如

"sku","Quantity Available
"
"ABCD","10
"

(请注意 Available 之后和值 10 之后的换行符,即结束引号之前)

知道如何在每行末尾的引号内去掉回车吗?

标签: powershell

解决方案


我的猜测是您的文本文件的行尾混乱,例如\n\r代替\r\n,或者可能是一些奇怪的 Unicode 字符。尝试:

Get-Content $FileName | ForEach-Object {
    $_.Trim()
} | ConvertFrom-Csv -Delimiter "`t" |
Export-Csv $OutputFile -NoTypeInformation

推荐阅读