mirror of
https://github.com/LCTT/TranslateProject.git
synced 2025-01-16 22:42:21 +08:00
158 lines
4.4 KiB
Markdown
158 lines
4.4 KiB
Markdown
|
[#]: collector: (lujun9972)
|
|||
|
[#]: translator: ( )
|
|||
|
[#]: reviewer: ( )
|
|||
|
[#]: publisher: ( )
|
|||
|
[#]: url: ( )
|
|||
|
[#]: subject: (Expand And Unexpand Commands Tutorial With Examples)
|
|||
|
[#]: via: (https://www.ostechnix.com/expand-and-unexpand-commands-tutorial-with-examples/)
|
|||
|
[#]: author: (sk https://www.ostechnix.com/author/sk/)
|
|||
|
|
|||
|
Expand And Unexpand Commands Tutorial With Examples
|
|||
|
======
|
|||
|
|
|||
|
![Expand And Unexpand Commands Explained][1]
|
|||
|
|
|||
|
This guide explains two Linux commands namely **Expand** and **Unexpand** with practical examples. For those wondering, the Expand and Unexpand commands are used to replace TAB characters in files with SPACE characters and vice versa. There is also a command called “Expand” in MS-DOS, which is used to expand a compressed file. But the Linux Expand command simply converts the tabs to spaces. These two commands are part of **GNU coreutils** and written by **David MacKenzie**.
|
|||
|
|
|||
|
For the demonstration purpose, I will be using a text file named “ostechnix.txt” throughout this guide. All commands given below are tested in Arch Linux.
|
|||
|
|
|||
|
### Expand command examples
|
|||
|
|
|||
|
Like I already mentioned, the Expand command replaces TAB characters in a file with SPACE characters.
|
|||
|
|
|||
|
Now, let us convert tabs to spaces in the ostechnix.txt file and write the result to standard output using command:
|
|||
|
|
|||
|
```
|
|||
|
$ expand ostechnix.txt
|
|||
|
```
|
|||
|
|
|||
|
If you don’t want to display the result in standard output, just upload it to another file like below.
|
|||
|
|
|||
|
```
|
|||
|
$ expand ostechnix.txt>output.txt
|
|||
|
```
|
|||
|
|
|||
|
We can also convert tabs to spaces, reading from standard input. To do so, just run “expand” command without mentioning the source file name:
|
|||
|
|
|||
|
```
|
|||
|
$ expand
|
|||
|
```
|
|||
|
|
|||
|
Just type the text and hit ENTER to convert tabs to spaces. Press **CTRL+C** to quit.
|
|||
|
|
|||
|
If you do not want to convert tabs after non blanks, use **-i** flag like below.
|
|||
|
|
|||
|
```
|
|||
|
$ expand -i ostechnix.txt
|
|||
|
```
|
|||
|
|
|||
|
We can also have tabs a certain number of characters apart, not 8 (the default value):
|
|||
|
|
|||
|
```
|
|||
|
$ expand -t=5 ostechnix.txt
|
|||
|
```
|
|||
|
|
|||
|
You can even mention multiple tab positions with comma separated like below.
|
|||
|
|
|||
|
```
|
|||
|
$ expand -t 5,10,15 ostechnix.txt
|
|||
|
```
|
|||
|
|
|||
|
Or,
|
|||
|
|
|||
|
```
|
|||
|
$ expand -t "5 10 15" ostechnix.txt
|
|||
|
```
|
|||
|
|
|||
|
For more details, refer man pages.
|
|||
|
|
|||
|
```
|
|||
|
$ man expand
|
|||
|
```
|
|||
|
|
|||
|
### Unexpand Command Examples
|
|||
|
|
|||
|
As you may have already guessed, the **Unexpand** command will do the opposite of the Expand command. I.e It will convert SPACE charatcers to TAB characters. Let me show you a few examples to learn how to use Unexpand command.
|
|||
|
|
|||
|
To convert blanks (spaces, of course) in a file to tabs and write the output to stdout, do:
|
|||
|
|
|||
|
```
|
|||
|
$ unexpand ostechnix.txt
|
|||
|
```
|
|||
|
|
|||
|
If you want to write the output in a file instead of just displaying it to stdout, use this command:
|
|||
|
|
|||
|
```
|
|||
|
$ unexpand ostechnix.txt>output.txt
|
|||
|
```
|
|||
|
|
|||
|
Convert blanks to tabs, reading from standard output:
|
|||
|
|
|||
|
```
|
|||
|
$ unexpand
|
|||
|
```
|
|||
|
|
|||
|
By default, Unexpand command will only convert the initial blanks. If you want to convert all blanks, instead of just initial blanks, use **-a** flag:
|
|||
|
|
|||
|
```
|
|||
|
$ unexpand -a ostechnix.txt
|
|||
|
```
|
|||
|
|
|||
|
To convert only leading sequences of blanks (Please note that it overrides **-a** ):
|
|||
|
|
|||
|
```
|
|||
|
$ unexpand --first-only ostechnix.txt
|
|||
|
```
|
|||
|
|
|||
|
Have tabs a certain number of characters apart, not **8** (enables **-a** ):
|
|||
|
|
|||
|
```
|
|||
|
$ unexpand -t 5 ostechnix.txt
|
|||
|
```
|
|||
|
|
|||
|
Similarly, we can mention multiple tab positions with comma separated like below.
|
|||
|
|
|||
|
```
|
|||
|
$ unexpand -t 5,10,15 ostechnix.txt
|
|||
|
```
|
|||
|
|
|||
|
Or,
|
|||
|
|
|||
|
```
|
|||
|
$ unexpand -t "5 10 15" ostechnix.txt
|
|||
|
```
|
|||
|
|
|||
|
For more details, refer man pages.
|
|||
|
|
|||
|
```
|
|||
|
$ man unexpand
|
|||
|
```
|
|||
|
|
|||
|
* * *
|
|||
|
|
|||
|
**Suggested read:**
|
|||
|
|
|||
|
* [**The Fold Command Tutorial With Examples For Beginners**][2]
|
|||
|
|
|||
|
|
|||
|
|
|||
|
* * *
|
|||
|
|
|||
|
When you working on large number of files, the Expand and Unexpand commands could be very helpful to replace unwanted TAB characters with SPACE characters and vice versa.
|
|||
|
|
|||
|
--------------------------------------------------------------------------------
|
|||
|
|
|||
|
via: https://www.ostechnix.com/expand-and-unexpand-commands-tutorial-with-examples/
|
|||
|
|
|||
|
作者:[sk][a]
|
|||
|
选题:[lujun9972][b]
|
|||
|
译者:[译者ID](https://github.com/译者ID)
|
|||
|
校对:[校对者ID](https://github.com/校对者ID)
|
|||
|
|
|||
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创编译,[Linux中国](https://linux.cn/) 荣誉推出
|
|||
|
|
|||
|
[a]: https://www.ostechnix.com/author/sk/
|
|||
|
[b]: https://github.com/lujun9972
|
|||
|
[1]: https://www.ostechnix.com/wp-content/uploads/2019/05/Expand-And-Unexpand-Commands-720x340.png
|
|||
|
[2]: https://www.ostechnix.com/fold-command-tutorial-examples-beginners/
|