ImageVerifierCode 换一换
格式:DOCX , 页数:8 ,大小:19.71KB ,
资源ID:12277679      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/12277679.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(Linux学习笔记个人版.docx)为本站会员(b****5)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

Linux学习笔记个人版.docx

1、Linux学习笔记个人版1, AWKawk是一个强大的文本分析工具,相对于grep的查找,sed的编辑,awk在其对数据分析并生成报告时,显得尤为强大。简单来说awk就是把文件逐行的读入,以空格为默认分隔符将每行切片,切开的部分再进行各种分析处理。awk有3个不同版本: awk、nawk和gawk,未作特别说明,一般指gawk,gawk 是 AWK 的 GNU 版本。awk其名称得自于它的创始人 Alfred Aho 、Peter Weinberger 和 Brian Kernighan 姓氏的首个字母。实际上 AWK 的确拥有自己的语言: AWK 程序设计语言 , 三位创建者已将它正式定义为

2、“样式扫描和处理语言”。它允许您创建简短的程序,这些程序读取输入文件、为数据排序、处理数据、对输入执行计算以及生成报表,还有无数其他的功能。使用方法awk pattern + action filenames尽管操作可能会很复杂,但语法总是这样,其中 pattern 表示 AWK 在数据中查找的内容,而 action 是在找到匹配内容时所执行的一系列命令。花括号()不需要在程序中始终出现,但它们用于根据特定的模式对一系列指令进行分组。 pattern就是要表示的正则表达式,用斜杠括起来。awk语言的最基本功能是在文件或者字符串中基于指定规则浏览和抽取信息,awk抽取信息后,才能进行其他文本操作

3、。完整的awk脚本通常用来格式化文本文件中的信息。通常,awk是以文件的一行为处理单位的。awk每接收文件的一行,然后执行相应的命令,来处理文本。调用awk有三种方式调用awk1.命令行方式awk -F field-separator commands input-file(s)其中,commands 是真正awk命令,-F域分隔符是可选的。 input-file(s) 是待处理的文件。在awk中,文件的每一行中,由域分隔符分开的每一项称为一个域。通常,在不指名-F域分隔符的情况下,默认的域分隔符是空格。2.shell脚本方式将所有的awk命令插入一个文件,并使awk程序可执行,然后awk命令

4、解释器作为脚本的首行,一遍通过键入脚本名称来调用。相当于shell脚本首行的:#!/bin/sh可以换成:#!/bin/awk3.将所有的awk命令插入一个单独文件,然后调用:awk -f awk-script-file input-file(s)其中,-f选项加载awk-script-file中的awk脚本,input-file(s)跟上面的是一样的。入门实例假设last -n 5的输出如下rootwww # last -n 5 =仅取出前五行root pts/1 192.168.1.100 Tue Feb 10 11:21 still logged inroot pts/1 192.168

5、.1.100 Tue Feb 10 00:46 - 02:28 (01:41)root pts/1 192.168.1.100 Mon Feb 9 11:41 - 18:30 (06:48)dmtsai pts/1 192.168.1.100 Mon Feb 9 11:41 - 11:41 (00:00)root tty1 Fri Sep 5 14:09 - 14:10 (00:01)如果只是显示最近登录的5个帐号#last -n 5 | awk print $1rootrootrootdmtsairootawk工作流程是这样的:读入有n换行符分割的一条记录,然后将记录按指定的域分隔符划分域,

6、填充域,$0则表示所有域,$1表示第一个域,$n表示第n个域。默认域分隔符是空白键 或 tab键,所以$1表示登录用户,$3表示登录用户ip,以此类推。如果只是显示/etc/passwd的账户#cat /etc/passwd |awk -F : print $1 rootdaemonbinsys这种是awk+action的示例,每行都会执行actionprint $1。-F指定域分隔符为:。如果只是显示/etc/passwd的账户和账户对应的shell,而账户与shell之间以tab键分割#cat /etc/passwd |awk -F : print $1t$7root /bin/bashd

7、aemon /bin/shbin /bin/shsys /bin/sh如果只是显示/etc/passwd的账户和账户对应的shell,而账户与shell之间以逗号分割,而且在所有行添加列名name,shell,在最后一行添加blue,/bin/nosh。cat /etc/passwd |awk -F : BEGIN print name,shell print $1,$7 END print blue,/bin/noshname,shellroot,/bin/bashdaemon,/bin/shbin,/bin/shsys,/bin/sh.blue,/bin/noshawk工作流程是这样的:先

8、执行BEGING,然后读取文件,读入有/n换行符分割的一条记录,然后将记录按指定的域分隔符划分域,填充域,$0则表示所有域,$1表示第一个域,$n表示第n个域,随后开始执行模式所对应的动作action。接着开始读入第二条记录直到所有的记录都读完,最后执行END操作。搜索/etc/passwd有root关键字的所有行#awk -F: /root/ /etc/passwdroot:x:0:0:root:/root:/bin/bash这种是pattern的使用示例,匹配了pattern(这里是root)的行才会执行action(没有指定action,默认输出每行的内容)。搜索支持正则,例如找root

9、开头的:awk -F: /root/ /etc/passwd搜索/etc/passwd有root关键字的所有行,并显示对应的shell# awk -F: /root/print $7 /etc/passwd /bin/bash这里指定了actionprint $7awk内置变量awk有许多内置变量用来设置环境信息,这些变量可以被改变,下面给出了最常用的一些变量。ARGC 命令行参数个数ARGV 命令行参数排列ENVIRON 支持队列中系统环境变量的使用FILENAME awk浏览的文件名FNR 浏览文件的记录数FS 设置输入域分隔符,等价于命令行 -F选项NF 浏览记录的域的个数NR 已读的记

10、录数OFS 输出域分隔符ORS 输出记录分隔符RS 控制记录分隔符此外,$0变量是指整条记录。$1表示当前行的第一个域,$2表示当前行的第二个域,.以此类推。统计/etc/passwd:文件名,每行的行号,每行的列数,对应的完整行内容:#awk -F : print filename: FILENAME ,linenumber: NR ,columns: NF ,linecontent:$0 /etc/passwdfilename:/etc/passwd,linenumber:1,columns:7,linecontent:root:x:0:0:root:/root:/bin/bashfile

11、name:/etc/passwd,linenumber:2,columns:7,linecontent:daemon:x:1:1:daemon:/usr/sbin:/bin/shfilename:/etc/passwd,linenumber:3,columns:7,linecontent:bin:x:2:2:bin:/bin:/bin/shfilename:/etc/passwd,linenumber:4,columns:7,linecontent:sys:x:3:3:sys:/dev:/bin/sh使用printf替代print,可以让代码更加简洁,易读 awk -F : printf(fi

12、lename:%10s,linenumber:%s,columns:%s,linecontent:%sn,FILENAME,NR,NF,$0) /etc/passwdprint和printfawk中同时提供了print和printf两种打印输出的函数。其中print函数的参数可以是变量、数值或者字符串。字符串必须用双引号引用,参数用逗号分隔。如果没有逗号,参数就串联在一起而无法区分。这里,逗号的作用与输出文件的分隔符的作用是一样的,只是后者是空格而已。printf函数,其用法和c语言中printf基本相似,可以格式化字符串,输出复杂时,printf更加好用,代码更易懂。awk编程变量和赋值除了

13、awk的内置变量,awk还可以自定义变量。下面统计/etc/passwd的账户人数awk count+;print $0; ENDprint user count is , count /etc/passwdroot:x:0:0:root:/root:/bin/bash.user count is 40count是自定义变量。之前的action里都是只有一个print,其实print只是一个语句,而action可以有多个语句,以;号隔开。这里没有初始化count,虽然默认是0,但是妥当的做法还是初始化为0:awk BEGIN count=0;print startuser count is ,

14、 count count=count+1;print $0; ENDprint enduser count is , count /etc/passwdstartuser count is 0root:x:0:0:root:/root:/bin/bash.enduser count is 40统计某个文件夹下的文件占用的字节数ls -l |awk BEGIN size=0; size=size+$5; ENDprint endsize is , sizeendsize is 8657198如果以M为单位显示:ls -l |awk BEGIN size=0; size=size+$5; ENDp

15、rint endsize is , size/1024/1024,M endsize is 8.25889 M注意,统计不包括文件夹的子目录。条件语句awk中的条件语句是从C语言中借鉴来的,见如下声明方式:if (expression) statement; statement; . .if (expression) statement; else statement2;if (expression) statement1; else if (expression1) statement2; else statement3;统计某个文件夹下的文件占用的字节数,过滤4096大小的文件(一般都是文

16、件夹):ls -l |awk BEGIN size=0;print startsize is , size if($5!=4096)size=size+$5; ENDprint endsize is , size/1024/1024,M endsize is 8.22339 M循环语句awk中的循环语句同样借鉴于C语言,支持while、do/while、for、break、continue,这些关键字的语义和C语言中的语义完全相同。数组 因为awk中数组的下标可以是数字和字母,数组的下标通常被称为关键字(key)。值和关键字都存储在内部的一张针对key/value应用hash的表格里。由于hash不是顺序存储,因此在显示数组内容时会发现,它们并不是按照你预料的顺序显示出来的。数组和变量一样,都是在使用时自动创建的,awk也同样会自动判断其存储的是数字还是字符串。一般而言,awk中的数组用来从记录中收集信息,可以用于计算总和、统计单词以及跟踪模板被匹配的次数等等。显示/etc/passwd的账户awk -F : BEGIN count=0; namecount = $1;count+; ENDfor (i = 0; i NR; i+) print i, namei /etc/passwd0 root1 daemon2 bin3 sys4 sync5 games.

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1