linux 三剑客(持续更新)排版后续再说,边学边记笔记

切记:seq命令用于产生从某个数到另外一个数之间的所有整数。sed才是处理文本的命令

 

在遇到扩展符号时,需要添加特定参数,| () +[] 为扩展符号时,必须添加参数

egrep/grep -E   sed -r

 

windows和linux互传文件,yum install lrzsz -y,直接拖拽就行了

 

空行的表达式:'/^$/'

 

  • grep命令  可以使用单引号或者双引号

-v     --取反

$      --结尾

^      --开头

查看文件中非注释的信息

grep -v "^#" qq.txt

 通过 ip address s ens33获取到ip地址,因为你使用扩展符号,所以要用egrep

ip address s ens33 | egrep "([0-9]+\.){3}[0-9]+"
#获取单行ip地址
ip address s ens33|egrep "([0-9]+\.){3}[0-9]+" -o|head -1

 批量创建用户

echo syscal{01..10} | xargs -n1 | sed -r 's#(.*)#useradd \1#g'|bash

 批量创建用户并设置初始密码为123456

seq -w 10| sed -r 's#(.*)# useradd bubu\1;echo 123456|passwd --stdin bubu\1#g'|bash

  

 

 

seq命令

-w 补零

 

  • sed命令  必须得用单引号使用表达式
  • -i 是直接对文件编辑插入操作  &&\如果不加这个,脚本中是异步执行的,加了这个就是同步执行
此例子是对本地ip地址进行修改
sed -ri 's#IPADDR=(.*)10#IPADDR=\111#g'  /etc/sysconfig/network-scripts/ifcfg-ens33 &&\
systemctl restart network &&\
echo "服务器地址是:"$(hostname -I)>>~/qq.txt
  • -n  根据sed原理可知 默认不输出文本    例子:sed -n '/test/p' ~/qq.txt

上面例子中的格式是固定的,p就是输出处理,print

n和i 一定要注意使用,否则会问题的,修改文件一定要备份源文件

  • p   print      输出信息
sed -n '1,3p' ~/qq.txt         #输出1到3行
  • i    insert    插入信息
 sed '1ithis is insert' qq.txt    #在第一行之前插入信息

因为i是直接修改文件的。所以修改之前记得备份文件,可以使用-i.bak的方法,这样编辑之前创建bak文件了

  • a     append  附加信息
sed '$athis is insert' qq.txt    #在最后一行之后插入信息
  • -e  需要多次执行sed命令时,用-e进行区分
sed -e '/bulusi/athis is new data'  -e "/yangci/i ddw" qq.txt    
  • d  删除信息
#删除第一行到第三行
sed '1,3d' qq.txt
#删除第三行到最后一行 sed '3,$d' qq.txt
#删除带有test的行 sed '/test/d' qq.txt

#删除第一行和第三行
sed '1d;3d' qq.txt

#不显示空行,相当于把行给删除了
sed '/^$/d' qq.txt  

#对带有#号进行修改 原有的格式是#,但可以/进行代替,所以含有#号的文本就可以修改了
sed 's/#best/bast/g'  

#获取ip地址
ip addr s eth0|sed -rn '3s#^.*net (.*)/20.*#\1#gp'

 

  • 题目

1.批量修改命名文件,在目录下有base1.txt~base10.txt,批量修改为base1~10.txt

find ~/base/ -type f|sed -r 's#(.*)\.(.*)#mv \1.\2 \1.jpg#g'|bash
#另一种方法,主要区别就是,&符号的使用,&是将找到信息放出来,可以理解为集合
find ~/base/ -type f|sed -r 's#(.*)txt#mv & \1jpg#g'|bash
#也可以使用rename命令
rename .txt .jpg base*.txt

2.将目录下test.c文件中将 printf("\n********\n");改为print("*******")

代码片段

注意:特色符号要用\修饰,不然不能准确让系统识别,匹配正则时)("符号都要\修饰

#include <stdio.h>
#include <stdlib.h>
#include <signal.h>
#include <sys/wait.h>
#include <unistd.h>
#include <sys/types.h>

int flag_wait=1;

void stop1() 
{
  flag_wait=0;
  printf("\nChild process1 is killed by parent!");
}

void stop2() 
{
  flag_wait=0;
  printf("\nChild process2 is killed by parent!");
}

void stop() 
{
  printf("\n 手动中断\n");
}


int main() 
{
  pid_t pid1,pid2;
  //如果出现终止操作,则调用stop函数。
  //signal监听到中断信号后,会重新回到原来执行的地方,也就是sleep(5)下一行代码
  signal(2,stop);
  while((pid1=fork())==-1);
  //主进程
  if(pid1>0) 
  {
    while((pid2=fork())==-1);
    //  主进程执行
    if(pid2>0) 
    {
      sleep(5);
      kill(pid1,16);
      kill(pid2,17);
      wait(0);
      wait(0);
      printf("\nParent process is killed!\n");
      exit(0);
    } else 
    {
      //  子进程2执行
      signal(17,stop2);
      while(flag_wait);
      exit(0);
    }
  } else 
  {
    //  pid1子进程执行
    signal(16,stop1);
    while(flag_wait);
    exit(0);
  }
  return 0;
}
View Code
sed -r 's#printf\(\"\\n(.*)\)#print("\\n\1)#g' test.c

 

 

 

 

  • awk
ip.log
2020-10-14     192.168.1.2     /api/bbs/login
2020-10-14     192.168.2.2     /api/bbs/login
2020-10-12     192.168.3.2     /api/bbs/login
2020-10-11     192.168.4.2     /api/bbs/login
2020-11-12     192.168.5.2     /api/bbs/login
2020-10-24     192.168.1.2     /api/bbs/login
2020-10-14     192.168.3.2     /api/bbs/home
2020-10-14     192.168.3.2     /api/bbs/menu
2020-11-12     192.168.5.2     /api/bbs/index
2020-10-24     192.168.6.2     /api/bbs/login
2020-10-14     192.168.1.2     /api/bbs/login
2020-10-14     192.168.1.2     /api/bbs/login
测试文本
  • 初学小提示

NR指的是行,大于第二行的信息,NF指的列(Date ip route)这样NF就是3了

awk "NR>2" ip.log

awk中使用BEGIN,BEGIN的作用可以理解为表头,END理解为结束后使用的字段。

awk 'BEGIN{ print("Date","ip","route") }{print $0}END{print "操作结束"}' ip.log|column -t

 

  • #输出指定列  

 下面是固定格式,默认以空格为分隔符,,$0表示的是一整行,$1,$3 是指只显示第一列和第三列

 awk '{print $1,$3}' ip.log 

#指定输出某行的列,/路径需要用\进行转义
 awk '/api\/bbs\/login/{print $1,$3}' ip.log

 

  • -F  指定分隔符的类型  这样就以:分隔符,找出第一列和第三列
 awk -F ":" '{print $1,$3}' ip.log 

#取最后一列
 awk -F ":" '{print $1,$NF}' ip.log 

#取最后第二列,一定要加小括号,不然就变成减法操作了
 awk -F ":" '{print $1,$(NF-1)}' ip.log 
#补充知识点 [ ,]里面是空格和逗号,代表的是以空格和为分隔符,分割的列数就是从左到右开始算,+号是多次匹配
uptime|awk -F "[ ,]+" '{print $9}'

 

 

 

 

  • gsub  格式:gsub(/需要替换的字符/,"修改后的信息",将哪列信息进行修改)
#将日期分隔符"-"替换为"#"符号
awk '$1~/2019/{gsub(/-/,"#",$1);print $0}' ip.log

 

 

  •  练手题目
#题1·找出192.168.1 ip段的访问路径
awk '/192.168.1.*/{print $1,$NF}' ip.log

#第二种做法(严谨) ~代表以第二列开始匹配以192.168.1开头的ip地址段
awk '$2~/^192.168.1.*/{print $1,$NF}' ip.log

#题2·找出ip后两位为5.2和1.2的ip段的访问时间和路径  解释:(5.2)$ 意思就是以这个结尾的,column -t 专治强迫症
awk '$2~/(5.2)$|(1.2)$/{print $1,$2,$3}' ip.log|column -t 

#题3·用awk计算出空行的行数
awk 'BEGIN{i=0}/^$/{i++}END{printf("总行数是%d\n",i)}' ip.log

#题4·统计普通用户和虚拟用户的数量(/etc/passwd 查看用户情况)
#普通用户(含有bash就是普通用户)
awk 'BEGIN{i=0}$NF~/bash/{i++}END{print i}' /etc/passwd
#虚拟用户(加了个!,表示取反)
awk 'BEGIN{i=0}$NF!~/bash/{i++}END{print i}' /etc/passwd

新测试数据

#题5·统计:符号第二列和第三列的总数

awk -F ":" 'BEGIN{print("第一总额","第二总额");sum1=0;sum2=0}$NF!~/^$/{sum1+=$2;sum2+=$3}END{print sum1,sum2}' ip.log|column -t

 

 

 

 

 

 

 

 

#使用三剑客,屏蔽#开头和空行的文本
grep -Ev '^#|^$' ip.log


awk '$1!~/^#|^$/{print $1,$2,$3}'  ip.log

 

 

sed原理

 

posted @ 2020-09-25 17:24  羊途踪  阅读(177)  评论(0编辑  收藏  举报