Line Break in PowerShell

Rohan Timalsina Oct 26, 2023
  1. Line Breaks in PowerShell
  2. Use `N to Break Lines in PowerShell
  3. Use [Environment]::NewLine to Break Lines in PowerShell
  4. Combine `N and [Environment]::NewLine to Break Lines in PowerShell
  5. Conclusion
Line Break in PowerShell

Line breaks are essential when you want to format your output or control the flow of text in your scripts. In PowerShell, you can achieve this using escape sequences and special characters.

In this tutorial, we’ll teach you the way to break lines in PowerShell.

Line Breaks in PowerShell

PowerShell includes a set of special character sequences for representing characters, such as line breaks and tabs. They are also known as escape sequences.

The backslash \ shows a special character in most programming languages. But, PowerShell uses the backtick character `.

So, escape sequences begin with ` and are case-sensitive. Here are some common escape sequences in PowerShell:

`0 Null
`a Alert
`b Backspace
`e Escape
`f Form feed
`n New line
`r Carriage return

Escape sequences are interpreted only when enclosed in double quotes (" ").

Use `N to Break Lines in PowerShell

One of the most common uses of escape sequences in PowerShell is to insert line breaks. We can use the new line `n character to break lines in PowerShell, and the line break or new line is added after the `n character.

The following example shows how to use `n to break lines in the output.

 powershellCopyWrite-Host "Welcome to the`nPowerShell Tutorial."

Output:

 textCopyWelcome to the
PowerShell Tutorial.

In the output above, the "Welcome to the" is displayed on the first line. Then, the `n character is encountered, causing a line break, and the cursor moves to the beginning of the next line and the "PowerShell Tutorial." is displayed on the second line.

We can also use multiple `n characters to create multiple line breaks. In this code example, the `n character is used to introduce a line break in the output, making it more readable.

 powershellCopyWrite-Host "Welcome `nto `nthe `nPowerShell Tutorial."

Output:

 textCopyWelcome
to
the
PowerShell Tutorial.

As we can see in the output, the string has multiple line breaks by using multiple `ncharacters.

In this next example, we have an array of fruits stored in the $fruits variable. Then, we create a list of fruits with each fruit name on a new line, we use the -join operator, which combines the elements of the array with the specified separator, in this case, the `n line break character.

 powershellCopy$fruits = 'Apple', 'Banana', 'Cherry', 'Date'

$fruitList = $fruits -join "`n"

Write-Host $fruitList

Output:

 textCopyApple
Banana
Cherry
Date

This results in a list of fruits, with each one displayed on a new line.

Use [Environment]::NewLine to Break Lines in PowerShell

Another method to create line breaks in PowerShell is by using the [Environment]::NewLine object, which is equivalent to (`n`r). The `r character moves the cursor to the beginning of the current line.

The following examples show how to use [Environment]::NewLine to break lines when displaying the array items in the output.

In the first example, we manipulate an array named $number containing 'one', 'two', 'three', and 'four'. Our objective is to format the output, displaying each element on a new line.

Next, we create a variable $new, which holds the platform-specific newline character [Environment]::NewLine. We then leverage the pipeline operator | to process each element in $number using ForEach.

Then, inside the ForEach block, we construct a string for each element by combining $_ (the element) and $new, creating a new line break after each element. This approach results in neatly formatted output, as each element is presented on a new line.

Example Code 1:

 powershellCopy$number = 'one', 'two', 'three', 'four'
$new = [Environment]::NewLine
$number | foreach { "$_$new" }

Output:

 textCopyone

two

three

four

The output showcases each element from the $number array on a new line.

In the next example, we begin by setting up data, defining an array called $numbers with values and a variable $newLine for line breaks. Then, we iterate through $numbers using ForEach-Object, calculate each element’s position in the array, and create formatted numbered lists with line breaks.

Next, these lists are stored in $numberedList. Finally, Write-Host displays the numbered lists, providing organized and formatted output.

Example Code 2:

 powershellCopy$numbers = 'one', 'two', 'three', 'four'
$newLine = [Environment]::NewLine

$numberedList = $numbers | ForEach-Object {
    $index = [array]::IndexOf($numbers, $_) + 1
    "$index. $_$newLine"
}

Write-Host $numberedList

Output:

 textCopy1. one
2. two
3. three
4. four

The output is a numbered list with each element from the $numbers array displayed in sequential order.

In this code example, we utilize the [Environment]::NewLine object to create line breaks in the output, making it more organized and easier to read.

Combine `N and [Environment]::NewLine to Break Lines in PowerShell

We can combine the `n escape sequence with [Environment]::NewLine to create custom line breaks.

In the following code, we create a custom two-line output. We define two variables, $line1 and $line2, each containing a line of text.

Then, to create platform-independent line breaks, we use a variable, $customLineBreak, which combines the "`n" newline character and [Environment]::NewLine. We then utilize Write-Host to display the content by concatenating $line1, $customLineBreak, and $line2 within double quotes, ensuring a clean two-line output.

Example Code:

 powershellCopy$line1 = "This is the first line"
$line2 = "This is the second line"
$customLineBreak = "`n" + [Environment]::NewLine
Write-Host "$line1$customLineBreak$line2"

Output:

 textCopyThis is the first line

This is the second line

In this example, a custom line break is created by combining the `n and [Environment]::NewLine to separate the two lines.

Conclusion

In conclusion, mastering line breaks and text formatting in PowerShell is essential for creating clear and organized scripts. We explored escape sequences, emphasizing the commonly used `n character for line breaks.

Additionally, we discussed the usage of [Environment]::NewLine for precise control over line breaks, exemplifying its application in array displays. By understanding these techniques, scriptwriters can produce well-structured and readable PowerShell scripts, ensuring efficient and effective communication.

Rohan Timalsina avatar Rohan Timalsina avatar

Rohan is a learner, problem solver, and web developer. He loves to write and share his understanding.

LinkedIn Website