怎么sed命令实现从行末匹配第二个字符并替换成另一个字符?
echo linux-libc-headers-3.18.31-r0|sed ‘s/-(*-*)$/,1/’
linux批量替换指定文件夹下的所有文件名(包括子目录下的文件)中的字符串?
思路:先找到文件,再替换find /yourfolder/subdir -exec {sed -i “s/oldstring/newstring/g” `grep oldstring -rl yourdir`};
Linux批量替换某种类型文件中的字符串-sed和grep命令使用?
思路:先找到文件,再替换
find/yourfolder/subdir-exec{sed-i”s/oldstring/newstring/g”`grepoldstring-rlyourdir`};
Linux下的shell编程,如何替换文件中的内容?
$0
例子:
#!/bin/sh
echo$0
#
#$0是程序名,不仅是shell脚本,
#所有的linux下的进程都是这样的.
#有几个变量非常重要:
#$0,$@$?等等.
如何去除Linux文件的^M字符?
在linux下,不可避免的会用VIM打开一些windows下编辑过的文本文件。我们会发现文件的每行结尾都会有一个^M符号,这是因为 DOS下的编辑器和Linux编辑器对文件行末的回车符处理不一致,
对于回车符的定义:
windows:0D0A
unixlinux: 0A
MAC: 0D
比较快捷的去除这些符号的方法有这么几种:
(1)是用VI的命令:
使用vi打开文本文件
vi dos.txt
命令模式下输入
:set fileformat=unix
:w
(2) VI下使用正则表达式替换
g/^M/s/^M//
或者
%s/^M//g
(3)使用sed 工具
sed ’s/^M//’ filename > tmp_filename
(4)既然window下的回车符多了‘r’,那么当然通过删除‘r’ ,也可以实现:
tr -d ‘r’
(5)最后一个方法是本人最常用的方法,个人觉得最方便
在终端下敲命令:
$ dos2unix filename
直接转换成unix格式,就OK了!~