Linux Shell删除行首空格:一篇轻松教学
Linux作为一个强大的操作系统,为用户提供了多种命令行工具和应用程序。Shell作为其中最关键的组成部分之一,为用户提供了一个与操作系统交互的界面。而在Shell中,删除行首空格是一个常见的操作,本篇文章将为您带来轻松的教学方法。
1. 使用sed命令删除行首空格
sed是Linux命令行中一个强大的文本编辑工具,可以对文本文件的内容进行修改和替换。使用sed命令删除行首空格是一种比较常见的方法,步骤如下:
– 打开需要修改的文件
在终端中输入以下命令,打开需要修改的文件:
$ vi filename
其中,filename是你需要修改的文件名。
– 使用sed命令删除行首空格
在打开的文件中,输入以下命令:
其中,%^表示行首,\+表示匹配一个或多个空格,//表示删除匹配到的内容。因此这个命令会删除所有行首的空格。

– 保存并退出文件
完成修改后,先按下Esc键,然后输入以下命令保存并退出文件:
这个命令会将修改后的文件保存,并退出vi编辑器。
2. 使用awk命令删除行首空格
awk是一个强大的文本处理工具,可以对文本文件进行各种操作。使用awk命令删除行首空格也是一种常见的方法,步骤如下:
– 打开需要修改的文件
在终端中输入以下命令,打开需要修改的文件:
$ vi filename
其中,filename是你需要修改的文件名。
– 使用awk命令删除行首空格
在打开的文件中,输入以下命令:
$ awk ‘{$1=$1};1’ filename
其中,$1表示每行的之一个字段(默认以空格为分隔符),将其赋值为空,再将字段与字段之间的空格重新拼接起来。最后的1表示打印所有行。
– 保存并退出文件
完成修改后,先按下Esc键,然后输入以下命令保存并退出文件:
这个命令会将修改后的文件保存,并退出vi编辑器。
3. 使用Perl命令删除行首空格
Perl是一种广泛用于文本处理和系统管理任务的编程语言,也可以用来删除行首空格。步骤如下:
– 打开需要修改的文件
在终端中输入以下命令,打开需要修改的文件:
$ vi filename
其中,filename是你需要修改的文件名。
– 使用Perl命令删除行首空格
在打开的文件中,输入以下命令:
$ perl -ne ‘s/^\s+//; print’ filename
其中,-ne选项表示逐行处理输入文本,s表示替换操作,^\s+表示匹配行首的一个或多个空格,;后面表示输出替换后的文本。
– 保存并退出文件
完成修改后,先按下Esc键,然后输入以下命令保存并退出文件:
这个命令会将修改后的文件保存,并退出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号寄存器.
\(.*\)/\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,18- 析取行中的第1到8个字符(用户名)和第18到行尾的字符(登录时间)
cut -ddchar
-ffields file其中,dchar是数据中分割各字段的分割符,fields表示要从文件file中析取出来的字段.
字
段编号从1开始,而且格式跟以前将的用来指定字符位置的数字一样(如-f1、2、8、-f1-3、-f4-)。
/etc/passwd
如果已知字段之间使用制表符分隔的,就可以给cut命令用-f选项而不用-c选项,好多了!还记得吧,这里用不着用-d选
项来指定分割符,因为
cut把制表符默认为分割符。
paste和cut正好相反,它不是把行分离开,而是把多行合并在一起。
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行
‘/est/d’删除包含test或Test的行
sed -n ‘20,25p’ test只显示文件test的第20行到第25行
‘1,10s/unix/UNIX/g’ intro报intro前10行中的unix改为UNIX
‘/jan/s/-1/-5/’将所有包含jan的行中第1个-1改为-5
sed ‘s/…//’
data删除data文件每一行的前3个字符
sed ‘s/…$//’>香港服务器首选树叶云,2H2G首月10元开通。树叶云(shuyeidc.com)提供简单好用,价格厚道的香港/美国云 服务器 和独立服务器。IDC+ISP+ICP资质。ARIN和APNIC会员。成熟技术团队15年行业经验。
linux中vi编辑器的撤销与前进命令为什么差那么多
vi 里 r 已经被占用了,r是替换u、r是vi个版本都有的命令,ctrl+r不是所有vi都有的
福州魔术店
安泰1家(买道具和网购的加上邮寄费的价格差不多,有的会贵一点,要有魔术实力可以讲价,魔术教学另算),宝龙地下游乐场里1家(报教学课程150多到1000多的课程,会员制,会价的道具和非会员的价格会差30多有的100多.),正大广场(五一广场旁)顶楼1家(和宝龙差不多),学生街首山路 爱转角酒吧旁1家(没去过,听说还行).
linux中增加用户并设置密码到root组的vi命令
为啥用vi弄 关键你这样没法设置密码 用户时可以加的 你在/etc/passwd 文件中添加一行就可以的 所属组位置写1就可以了
发表评论