轻松教学:Linux Shell删除行首空格 (linux shell 删除行首空格)

Linux Shell删除行首空格:一篇轻松教学

Linux作为一个强大的操作系统,为用户提供了多种命令行工具和应用程序。Shell作为其中最关键的组成部分之一,为用户提供了一个与操作系统交互的界面。而在Shell中,删除行首空格是一个常见的操作,本篇文章将为您带来轻松的教学方法。

1. 使用sed命令删除行首空格

sed是Linux命令行中一个强大的文本编辑工具,可以对文本文件的内容进行修改和替换。使用sed命令删除行首空格是一种比较常见的方法,步骤如下:

– 打开需要修改的文件

在终端中输入以下命令,打开需要修改的文件:

“`

$ vi filename

“`

其中,filename是你需要修改的文件名。

– 使用sed命令删除行首空格

在打开的文件中,输入以下命令:

“`

:%s/^ \+//

“`

其中,%^表示行首,\+表示匹配一个或多个空格,//表示删除匹配到的内容。因此这个命令会删除所有行首的空格。

– 保存并退出文件

完成修改后,先按下Esc键,然后输入以下命令保存并退出文件:

“`

:wq

“`

这个命令会将修改后的文件保存,并退出vi编辑器。

2. 使用awk命令删除行首空格

awk是一个强大的文本处理工具,可以对文本文件进行各种操作。使用awk命令删除行首空格也是一种常见的方法,步骤如下:

– 打开需要修改的文件

在终端中输入以下命令,打开需要修改的文件:

“`

$ vi filename

“`

其中,filename是你需要修改的文件名。

– 使用awk命令删除行首空格

在打开的文件中,输入以下命令:

“`

$ awk ‘{$1=$1};1’ filename

“`

其中,$1表示每行的之一个字段(默认以空格为分隔符),将其赋值为空,再将字段与字段之间的空格重新拼接起来。最后的1表示打印所有行。

– 保存并退出文件

完成修改后,先按下Esc键,然后输入以下命令保存并退出文件:

“`

:wq

“`

这个命令会将修改后的文件保存,并退出vi编辑器。

3. 使用Perl命令删除行首空格

Perl是一种广泛用于文本处理和系统管理任务的编程语言,也可以用来删除行首空格。步骤如下:

– 打开需要修改的文件

在终端中输入以下命令,打开需要修改的文件:

“`

$ vi filename

“`

其中,filename是你需要修改的文件名。

– 使用Perl命令删除行首空格

在打开的文件中,输入以下命令:

“`

$ perl -ne ‘s/^\s+//; print’ filename

“`

其中,-ne选项表示逐行处理输入文本,s表示替换操作,^\s+表示匹配行首的一个或多个空格,;后面表示输出替换后的文本。

– 保存并退出文件

完成修改后,先按下Esc键,然后输入以下命令保存并退出文件:

“`

:wq

“`

这个命令会将修改后的文件保存,并退出vi编辑器。

Linux Shell删除行首空格的方法有很多种,本篇文章介绍了三种比较常见的方法:使用sed命令、使用awk命令、使用Perl命令。读者可以根据自己的喜好和需要选择其中的一种方法进行操作,也可以尝试使用其他的方法。不管使用哪种方法,只要掌握了删除行首空格的技巧,相信Linux Shell操作就会更加得心应手。

相关问题拓展阅读:

shell脚本如何删除指定字符串,文档如下:

cat filename.txt | awk ‘{print $1″ “$2}’

用正则匹配就可以了。

shell脚本regex正则表达式 和 字符串替换

任意字符

^行首匹配

$行尾匹配伏亩

^$表示空行,不含字符的行

^

$匹配只有单个空格的行

^

Z>搜索以大写字母开头的行

匹配大写字母意外的任意字符

*表示匹配0个或若干个字符,如:a*,表示匹配0个或若干个a;

aa*表示匹配至少1个a

.*来表示0或若干个任意字符

e.e*表示匹配之一个e和最后一个e之间的任意字符

匹配一

个连字符或数字

a-z>匹配一个>或者字母

\{min,max\}匹配任意数目的字符串

\{10\}只匹配10个

a-z字符的字符串

s/.\{5\}$// 删除每行的最后5个字符

\(…\),n是1到9的数字,表示存储用的寄存器,用\n来引

用存在寄存器中的内容

^\(.\)\1匹配行首的之一个字符,并将该字符存到1号寄存器中,然后匹配1号寄存器中的内容,这由\1的描述。该正则

表达式的最终效果是,如果一行的头两个字符相同,就匹配他们。

^\(.\).*\1$匹配一行中的头一个字符(^.)跟最后一个字符(\1$)相

同的行。.*匹配中间的所有内容

^\(…\)\(…\)行中头三个字符存在1号寄存器,接着的三个字符存悔中在2号寄存器.

s/\(.*\)

\(.*\)/\2 \1/g 交换两个字段

.任何字符

^行首

$行尾

*前导的正则表达式重复0或若干次

符表>字符中的任一字符

a..表示a后的2个字符

^wood表示行首的wood

x$表示行为的x

^INSERT$只包含

字符串INSERT的行

^$不包含任何字符的行

x*表示缺前森0或若干个连续的x

xx*表示1或多个连续的x

.*表示0活若干

个字符

w.*s表示以w开始,s结尾的任何字符串

小写或大写的t

表示任一不在字符表中的字符

\{min,max\}表示前导的正则表达式重复只烧min次,至多max次\{3,9\}表示3到

9个数字

\(...\)表示将小括号中匹配的字符串存储到下一个寄存器中(1-9),

^\(.\)表示行中第1个字符存到1号寄存器

^\

(.\)\1表示行首恋歌字符,且他们相同

cut -c5 file把file文件中没行的第5个字符析取出来;

用逗号分割的数

值列表,如-c1,13,50把第1,13,50个字符析取出来

cut -c20-50把第20到50之间的字符析取出来

who | cut

-c1-8

who | cut -c1-8,18- 析取行中的第1到8个字符(用户名)和第18到行尾的字符(登录时间)

cut -ddchar

-ffields file其中,dchar是数据中分割各字段的分割符,fields表示要从文件file中析取出来的字段.

段编号从1开始,而且格式跟以前将的用来指定字符位置的数字一样(如-f1、2、8、-f1-3、-f4-)。

cut -d: -f1

/etc/passwd

如果已知字段之间使用制表符分隔的,就可以给cut命令用-f选项而不用-c选项,好多了!还记得吧,这里用不着用-d选

项来指定分割符,因为

cut把制表符默认为分割符。

paste和cut正好相反,它不是把行分离开,而是把多行合并在一起。

paste

names numbrs文件names中的每一行都和numbers中的对应行显示在一起,中间用制表符分割。

如果不想用制表符作默认分割,

可以使用-dchars指定分割符

paste -d'+' names addresses numbers

-s选项告诉paste把同

一文件中的行粘贴在一起,而不是从其他文件。如果只指定一个文件名,其效果是把文件中的所有行合并成一行,原来隔行之间用制表符或者有-d选项指定的分割

符分割。

sed是用来编辑数据的程序,意指流编辑器(stream editor)。与ed不同,sed不能用于交互,

-n选

项,然后使用p命令显式指定

sed -n '1,2p' file只显示前2行

sed -n '/Unix/p'

file只打印包含Unix的行

删除行

d删除整行文件

sed '1,2d' file删除1和2行

记住sed默认把输入

的所有行写入标准输出,所以生于行的文字,也就是从第3行到结尾,都被写入标准输出。

sed '5d'删除第5行

sed

'/est/d'删除包含test或Test的行

sed -n '20,25p' test只显示文件test的第20行到第25行

sed

'1,10s/unix/UNIX/g' intro报intro前10行中的unix改为UNIX

sed

'/jan/s/-1/-5/'将所有包含jan的行中第1个-1改为-5

sed 's/...//'

data删除data文件每一行的前3个字符

sed 's/...$//' data删除data文件每一行的最后3个字符

sed -n 'I'

text显示文件text的所有行,把所有不可打印字符显示为\nn,制表符显示为\t

过滤器tr用来转换来自标准输入的字

符,tr命令的一般格式为

tr from-chars to-chars

tr e x 或>或glx

-d 目录

-e 存在

-f 普通文件

-r 进程可读文件

-s 长度不为0

-w

进程可写文件

-x 可执行

-L 链接文件

$# 传给程序的参数个数,或者执行set命令设置的参数个数

$*

对位置参数等的集中引用

$@ 跟$*相似,区别在于当加入双引号后("$@"),集中引用位置参数"$1","$2"...等

$0

正执行的程序名

$$ 正执行程序的进程id

$! 最后一个发生后台运行的程序的进程id

$? 最后一个在前台执行的程序的退出状态

$-

当前有效选项标志

`command`符号之间的内容为需要执行的命令

make -C /lib/modules/`uname -r`/build

M=`pwd`

使用echo可以显示字符串,但是不能格式化字符串,可以使用printf实现

printf "format" arg1 arg2

...

ln -s from to 把from链接到to上,所以to是from的符号链接

tree -d只显示目录

tree -L

2显示2级目录

字符串比较

s1 = s2 s1等于s2

s1 != s2 s1不等于s2

s

s1不为空

-n ss1不为空

-z ss1为空

整数比较操作

-eq 等于

-ge

大于或等于

-gt 大于

-le 小于或等于

-lt 小于

-ne 不等于

字符串比较

"$x1" -eq 5 >整数比较

-a 逻辑与操作

-o 逻辑或操作

command1 &&

command2

则先执行command1,如果返回的退出状态

为0,则执行command2;如果command1返回的退出状态非0,则跳过command2

command1 ||

command2

和上边的&&差不多,只是,仅仅当command1返回非0时,才执行command2

#!/bin/sh

append2=0

include_lib=1

if

;then

rm cscope_i

fi

for cscope_file in $*; do

if || ;then

# if

$cscope_file = '-a' >;then

# append2=1

# continue

#

fi

#

# if ;then

#

include_lib=0

# continue

# fi

if

>;then

find $cscope_file -maxdepth 1 -name '*.' -o -name

'*.'>>cscope_i

else

find $cscope_file -name

'*.' -o -name '*.'>>cscope_i

fi

else

if

$cscope_file = '-a' >;then

append2=1

elif

>;then

include_lib=0

else

echo "Error: cannot read file

$cscope_file"

fi

fi

done

if ;then

if

"$include_lib" = "1" >;then

cscope -bi cscope_i

else

cscope -bki cscope_i

fi

rm cscope_i

fi

linux shell 删除行首空格的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于linux shell 删除行首空格,轻松教学:Linux Shell删除行首空格,shell脚本如何删除指定字符串,文档如下:的信息别忘了在本站进行查找喔。


数据运维技术 » 轻松教学:Linux Shell删除行首空格 (linux shell 删除行首空格)