linux Shell学习笔记第一天

以下是Shell学习1-2天学习笔记

————————-我是分隔符—————————

硬件去执行, 内核与硬件之间进行操作。

命令解析器。

shell脚本的组成元素

  1. 系统命令

  2. 文本处理工具(sort、grep、sed、awk…)

  3. 变量

  4. 条件判断

  5. 环循结构

  6. 函数

    Shell Scripts Center(SSC)


———————————————————————————-

非负Grep / awk

几天。 统计Wc

Sort 排序 sort|head / sed
字段处理 awk

数据区域判断 awk |wc

显示文本: echo [选项] 文本

-n 不要自动换行

-e 解析转义符

a 发出警告音

c 最后不加上换行符号

f 换行

r 回车

彩色文本

Echo –e “33[40;35m….]”

echo “Hello,world”

echo –e “33[40;35mHell,world33[0m"

sort [选项]输入文件

-o 输出文件

-d 按字典顺序排序 a-z

-n 按数字大小输出 0-9

-r 逆序输出 z-a 9-0

-k 指定分类是域上的数字分类

-t 域分割符;用非空格或tab键分割域

more /etc/passwd 分页显示

sort –d /etc/passwd|more 中间的|是反倒符号。 将前面处理的交给后面处理     先排序。后分页显示

sort –k3 –n –r –t: /etc/passwd|more

从大到小

wc [参数] [文件名]

-c 统计字符数量

-l统计行数

-w 统计单词数量 空格区分

diff [选项] 文件/目录 文件/目录

diff /etc/passwd /etc/passwd.bak

    -q 仅显示有无差异,不显示详细的信息

    -c 显示全部内文,并标出不同之处。

    -b 不检查空格字符的不同

    -B 不检查空白行

    -r 比较子目录中的文件。

grep 搜索匹配 支持正则表达式

grep

-c 只打印匹配模式的行编号记数

-I 在匹配文本时忽略大小写

    -n 在每行前显示其行编号

    -v 逆向输出,打印不匹配的行

-f file 要匹配的字符串列表在filezhong

grep ‘[Tt]his' file1.txt 设置大小写

grep ‘^[^#]‘ file2.txt 不匹配行首

grep “s…n” file3.txt 匹配任意字符

sed 行编辑命令
    s 替代

    i 插入

    a 附加

    d    删除全部匹配的行

    D    删除首次匹配的行

sed可以做什么(”行”为基础)

删除

改变

添加

插入

替换

示例

sed –n '1,4p' /etc/passwd p是打印 -n 不显示原文件 打印1-4行

sed ‘/80/D' file.txt 首次出现80的行进行删除

sed ‘s/var/usr/g' file.txt 将所有的var替换成usr g代表所有

sed '50,$s/help/man/g' file.txt 替换从50行到最后一行的help替换为man 前49不管

awk 可以处理列,也可以处理行,可以定位到第几行,第几列

awk [选项] ‘awk脚本' 输入文件

    -F fs 使用fs作为输入记录的字段分隔符 = sort –t

    -f filename 从文件filename读取awk_script(awk脚本)

    -v var=value 为awk_script 设置变量

awk的内置变量





























变量 功能 默认
FS =大写F 输入字段分隔符 空格或tab
RS 输入记录分隔符 换行
OFS =out FS 输出字段分隔符 空格或tab
ORS 输出记录分隔符 换行
NF 常用 当前记录非空字段的编号  
NR 常用 从所有文件读入的记录号  

示例

awk –F : ‘{print NR,$1,$2}' /etc/passwd

awk –F : ‘{print NR,$1,$NF}' /etc/passwd $NF 提取最后一行

awk –F : ‘NR%10==5{PRINT nr,$0}' /etc/passwd NR= 当前处理的行数 除10求余=5打印当前的行数,进行输出 $0 整行输出,比如5、15、25 打印出来

awk –F : ‘NR==8,NR==13 {print NR,$0}' /etc/passwd 指定8行和13行。

awk工作原理(工具)

$NF $NR $1 第一列 $2 第二列 $0 一整行

实际测试

awk –F: ‘{print $1,$3}'/etc/passwd

awk –F: ‘{print $1,$NF}'/etc/passwd

awk –F: ‘{print NR,$1,$NF}'/etc/passwd NR行号

awk –F: ‘NR==5,NR==8{print NR,$1,$NF}'/etc/passwd 指定5-8行

awk –F: ‘NR%10==5{print NR,$1,$NF}'/etc/passwd 除10求余

课程示例测试

1、grep –v “-” file.txt 去除所有带负号的数据 -v显示没有的 没有的话则显示只有-的

2、wc -l file.txt显示所有行数 grep –v “-” file.txt |wc –l 统计所有没有负数的

3、sort –n –r –k4 file.txt |sed –n '1p' 排序第四列 没有分隔符(即空格),-n数字 –r 从大到小 sed管道 显示第一行 sed –n不显示原文件

sort –n –r –k4 file.txt |head -1 读取第一个数据 head 第一行

4、awk ‘{if($NF>3){print $0}}' file.txt NF 最后一列大于3 则打印一整行

5、awk ‘{if($4>0,&&$4<15){print $0}}' file.txt 列出第四列 大于0小于15 输出整行

awk ‘{if($4>0,&&$4<15){print $0}}' file.txt |wc –l 显示行数

练习:

  1. grep和awk

    awk ‘{if($1>200801011){[print $0}}'file.txt

2、

处理命令回顾:

统计文本                wc

文本排序                sort

文本/目录对比            diff

在文件中查找关键行        grep / sed

在行文本中添、删、改    sed

在列文本中显示指定列    awk

在列文本中进行计算        awk

在列文本进行条件选择    awk

(0)

相关推荐

  • linux Shell学习笔记第五天

    第五天:函数与任务调度 函数的优势 分而治之f 协同合作 方便管理 维护简单 函数的结构 function 函数名() { 命令1 命令2 命令3 } 函数的参数传递 向函数传递参数就像在一般脚本中使用特殊变量$1,$2,$3-$9一样,函数取得所传参数后将原始参数传回shell脚本,因此最好先在函数内重新设置变量保存所传的参数.这样如果函数有一点错误,就可以通过已经本地化的变量名迅速加以跟踪. 函数文件 当你手机一些经常使用的函数时,可以将之放入函数文件中并将文件载入shell. 文件头应包含

  • linux Shell学习笔记最后一节,温故与知新

    脚本编写技巧 脚本文件名命名规则 文件名的字符包括 字母.数字."."."_"和"-", 注意:脚本的文件名命名不能以数字开头. 脚本文件名的命名,尽量使用英文单词.词组或短句的缩写. 脚本版本管理: 脚本作用.主版本号.修改次数.shell类型 变量命名规范 变量名可以由数字和字母组成 变量名采用全部英文字符小写的方式 变量名称尽量使用缩写,最好不要超过6个字符 ${变量名} 例:${port},${ipaddr}- 脚本代码注释规范 脚本代码

  • 如何短时间内学好一门语言 shell脚本语言为例

    这里我分享的是学习计算机shell脚本语言的方法,可能你不是在软件行业,但我建议也看看,因为我并没有讲什么技术细节,主要分享的是提炼出的通用性方法,这是对学习任何东西都是有用的. 当然,如果你好奇心足够强的话,建议也可以按照下面的方法来尝试一下,因为科学家已经预测:以后的世界就是一个软件定义的世界,机器人和人工智能会非常普及,而支持它们运行的除了我们看得见的硬件,最关键的就是里面的软件. 所以,学会编程以后就不仅仅只是软件从业人员需要掌握的技能,任何人都可以掌握它,既可以用它来不断提高工作效率,

  • linux Shell学习笔记第四天

    本节课的脚本也同样共享在share中了. 第四天:循环结构 内容大纲: 应用实例分析 for循环 while循环 for循环的原理 达到效果 根据昨天的菜单修改. 选择1.2.3后还会提示是否继续选择的功能.选择4仍然是退出操作. for variable in list list 变量列表池 do command1 command2 done 实例一 forlist.sh #!/bin/bash #for with list for loop in 1 2 3 4 5 定义loop的变量 1

  • 学习shell脚本之前的基础知识[图文]

    日常的linux系统管理工作中必不可少的就是shell脚本,如果不会写shell脚本,那么你就不算一个合格的管理员.目前很多单位在招聘linux系统管理员时,shell脚本的编写是必考的项目.有的单位甚至用shell脚本的编写能力来衡量这个linux系统管理员的经验是否丰富.笔者讲这些的目的只有一个,那就是让你认真对待shell脚本,从一开始就要把基础知识掌握牢固,然后要不断的练习,只要你shell脚本写的好,相信你的linux求职路就会轻松的多.笔者在这一章中并不会多么详细的介绍shell脚本

  • Shell脚本编程中常用的数学运算实例

    这部分主要讨论数学相关的shell脚本编程. 加法运算 新建一个文件"Addition.sh",输入下面的内容并赋予其可执行的权限. 复制代码 代码如下: #!/bin/bash echo "Enter the First Number: " read a echo "Enter the Second Number: " read b x=$(expr "$a" + "$b") echo $a + $b =

  • shell脚本学习与总结

    1.shell 脚本是区分小写的2.Unix特殊字符有: ( ; $ ? & * () [] ` ' " + 使用其时要进行转义()3.Shell的注释以#开头4.函数的定义Function fuction_name(){Command to execute}调用时直接用function_name.5.控制结构1)If...then语句If [ test_command ]ThenCommandsif2)If...then...else语句If [ test_command ]ThenC

  • linux shell数组深入学习理解

    bash shell只支持一维数组,但参数个数没有限制. 声明一个数组:declare -a array(其实不用声明,按数组方式直接赋值给变量即可,BASH就知道那是数组) 数组赋值:(1) array=(var1 var2 var3 ... varN)(2) array=([0]=var1 [1]=var2 [2]=var3 ... [n]=varN)(3) array[0]=var1    arrya[1]=var2    ...    array[n]=varN 计算数组元素个数:${#

  • shell中case的用法学习笔记

    shell中的case语句: 可以把变量的内容与多个模板进行匹配,再根据成功匹配的模板去决定应该执行哪部分代码. 使用格式:case 匹配母板 in模板1 [ | 模板2 ] - ) 语句组 ;;模板3 [ | 模板4 ] - ) 语句组 ;;esaccase语句的匹配是从上往下地匹配顺序.因此,case语句编写的原则是从上往下,模板从特殊到普通.在C语言里,case语句中有default模板,而在shell程序设计中,可能将模板写成*,就可以完成相同的功能. 例1: 复制代码 代码如下: #!

  • linux Shell学习笔记第三天

    第三天:条件选择 大 纲 应用实例分析 条件测试 if-else-fi case-in-esac 实现功能菜单: 执行脚本后 按1,显示当前时间 按2,显示CPU负载 按3,显示剩余内存 按0,退出脚本 按其他字符,提示超出选择范围后退出 分析步骤. #date +%T uptime awk截取 free –m 条件测试格式 #test –option obj #[ -option obj ] 返回结果 表达式内容测试结果是真的 表达式内容测试结果是假的 测试的对象分类 执行结果(执行成功或失败

随机推荐