how to convert a file from DOS to Unix

11,596

Solution 1

It could be as simple as

Get-Content in.csv -raw | % {$_ -replace "`r", ""} | Set-Content -NoNewline out.csv

Above method will work on powershell version 3+. If you are below that you can use below method instead. Almost same as one of the other answers here.

$csvdata = [io.file]::ReadAllText('in.csv') | % {$_ -replace "`r",""}
[io.file]::WriteAllLines('out.csv', $csvdata)

Solution 2

Try this:

$txt = (Get-Content -Raw myFile.txt) -replace "`r`n","`n"
[io.file]::WriteAllText('c:\path\to\myFile.unix.txt', $txt)

I used WriteAllText rather than Set-Content because Set-Content adds a carriage return and a line feed to the end of the file, and there doesn't seem to be any way to suppress that.

I think that the -Raw parameter to Get-Content might be a PowerShell 3 thing, so if you are using an earlier version, you might need to do it like this:

$txt = [io.file]::ReadAllText('c:\path\to\myFile.txt') -replace "`r`n","`n"
[io.file]::WriteAllText('c:\path\to\myFile.unix.txt', $txt)
Share:
11,596
judi
Author by

judi

Updated on June 12, 2022

Comments

  • judi
    judi almost 2 years

    I need to convert a file from DOS to Unix in PowerShell.

    I know this can be very much easily done in Unix:

    dos2unix file newfile