linux文本处理shell命令
所属分类 linux
浏览量 1080
find grep xargs sort uniq tr cut paste wc sed awk
find . -name "*.txt" -print
find . ! -name "*.txt" -print
find . -name "*.txt" -o -name "*.java"
find . -maxdepth 1 -name "*.txt" -print
大于2k的文件
find . -type f -size +2k
大于20M的文件
find . -type f -size +20M
最近两天修改过的文件
find . -mtime 2 -name "*.txt"
-atime 访问时间 (单位天)
-mtime 修改时间 (内容被修改)
-ctime 变化时间 (元数据或权限变化)
find . -name ".DS_Store" -delete
执行动作 exec
将找到的文件复制到指定目录
find . -mtime 2 -name "*.txt" -exec cp {} ~/tmp \;
{} 替换成相应的文件名
xargs
find . -name '.DS_Store'|xargs rm
find . -name "*.txt" | xargs grep 'tiger'
sort
第一列作为数字降序排序
jstack 7363|grep java.lang.Thread.State: |sort|uniq -c|sort -rn -k 1
75 java.lang.Thread.State: WAITING (parking)
34 java.lang.Thread.State: RUNNABLE
9 java.lang.Thread.State: TIMED_WAITING (sleeping)
8 java.lang.Thread.State: TIMED_WAITING (parking)
3 java.lang.Thread.State: TIMED_WAITING (on object monitor)
2 java.lang.Thread.State: WAITING (on object monitor)
tr 转换
制表符转空格
cat text| tr '\t' ' '
删除所有数字
cat file | tr -d '0-9'
压缩
echo "hell o 123" |tr -s ' '
df |tr -s " " |cut -d" " -f5
cut按列切分
获取第2列和第4列
cut -f2,4 filename
cut -f2,4 -d"," pet.txt
-d 指定分隔符
第一到5个字符
cut -c1-5 file
前2个字符
cut -c-2 file
-b 以字节为单位
-c 以字符为单位
-f 以字段为单位
paste按列拼接文本
paste -d"," 01.txt 02.txt
wc统计行和字符
统计行数
wc -l file
统计单词数
wc -w file
统计字符数
wc -c file
sed文本替换
替换每一行的第一处匹配的text
sed 's/text/replace_text/' file
sed 's/abc/xyz/' data.txt
全部替换
sed 's/text/replace_text/g' file
sed 's/abc/xyz/g' data.txt
sed -i 's/text/repalce_text/g' file
-i 原文件
移除空白行
sed '/^$/d' file
awk数据流处理
1.执行begin中语句块
2.从文件或stdin中读入一行,然后执行statements2,重复这个过程,直到文件全部被读取完毕;
3.执行end语句块;
print 打印当前行 使用不带参数的print时,打印当前行;
echo -e "line1\nline2" | awk 'BEGIN{print "start"} {print } END{ print "End" }'
最常用的 10 条 shell 命令
history | awk '{print $2}' | sort | uniq -c | sort -nr |head -n 10
$2 第二列
NR 记录数量 当前行号
NF 字段数量 当前行字段数
$0 当前行
$1 第一个字段内容
$2 第二个字段内容
echo -e "a b c\nx y z" | awk '{print NR":"$0"-"$1"-"$2}'
1:a b c-a-b
2:x y z-x-y
统计文件行数
awk ' END {print NR}' file
awk实现head、tail命令
head
awk 'NR< =10{print}' filename
tail
awk '{buffer[NR%10] = $0;} END{for(i=0;i<11;i++){ \ print buffer[i %10]} } ' filename
Linux查找命令使用及其区别
linux之grep命令
linux sort 命令
上一篇
下一篇
Java 正则表达式
Elasticsearch实用监控指标TOP10
三国演义里的职场道理
elasticsearch集群搭建
Elasticsearch analyzer 和 search_analyzer
Elasticsearch5快速入门