linux相关(find/grep/awk/sed/rpm)

如何查找特定的文件:

  find :在指定目录下查找文件

  find -name "filename" :从当前目录查找文件

  find / -name "filename" : 从根目录下查找文件

  find ~ -name "target*" :从用户目录查找以target开头的文件  

  find ~ -iname "target*":从用户目录查找以target开头的文件(忽略target的大小写)

man:查看帮助

  man find

 

根据文件内容检索文件:

  grep [options] pattern file  :查找文件里符合条件的字符串,并打印匹配的行

   grep "test" target*:查找以target开头的文件中的test内容

管道操作符 |:

  可将指令链接起来,前一个指令的输出作为后一个指令的输入,管道命令只能执行前一个命令的正确输出,不能执行错误

   右边命令必须能够接受标准输入流,否则传递过程中数据就会被抛弃

  例子:

  grep 'partial\[true\]' basc.info.log  ==> 检索log文件中包含partial[true]字符的行

  grep -o 'engine\[[0-9a-z]\]' ==》检索出engine[11111111111],符合正则表达式的内容 

  grep -v 'grep' ==》排除包含grep的命令   如 ps -ef | grep java | grep -v 'grep'   

 

对文件内容做统计:

  awk [options] 'cmd' file:一次读取一行文本,按输入分隔符进行切片,切成多个组成部分,将切片直接保存在内建变量中,$1,$2...$0表示行的全部

   支持对单个切片的判断,支持循环判断,默认分隔符为空格

   例子:

    awk '{print $1,$4}' netstat.txt

    

    awk '$1=="tcp" && $2==1{print $0}' netstat.txt

    

    NR:代表表头

    awk '($1=="tcp" && $4==1) || NR==1 {print $0}' netstat.txt

    

    修改默认分隔符:

    awk -F "," 'print{ $2}'

    

  做统计:

  

 

批量替换文本内容:

  sed [options] 'sed command' filename: 流编辑器,适用于对文本行内容进行处理

  例子:

  sed 's/^Str/String/' replace.java ==》替换Str开头的文本,  s表示字符串操作(该操作并不会修改原文件的内容,只是将修改后的内容输入的屏幕)

  

  如果需要修改源文件:sed -i 's/^Str/String/' replace.java

  

 

 

RPM默认安装路径:

/etc 一些设置文件放置的目录如/etc/crontab
/usr/bin 一些可执行文件
/usr/lib 一些程序使用的动态函数库
/usr/share/doc 一些基本的软件使用手册与帮助文档
/usr/share/man 一些man page文件

 

posted @ 2019-11-14 10:38  xj-record  阅读(191)  评论(0编辑  收藏  举报