linux shell 如何统计文件

linux shell 如何统计文件,第1张

先把内容写到一个文件btxt

然后再执行脚本

#!/bin/bash

echo "username copy_file create_folder login download_file"

a=`cat btxt|grep 产品管理员|grep copy_file|awk '{print $1}'`

b=`cat btxt|grep 产品管理员|grep create_folder|awk '{print $1}'`

c=`cat btxt|grep 产品管理员|grep login|awk '{print $1}'`

d=`cat btxt|grep 产品管理员|grep download_file|awk '{print $1}'`

echo "产品管理员 $a $b $c $d"

e=`cat btxt|grep 刘欣|grep copy_file|awk '{print $1}'`

f=`cat btxt|grep 刘欣|grep create_folder|awk '{print $1}'`

g=`cat btxt|grep 刘欣|grep login|awk '{print $1}'`

h=`cat btxt|grep 刘欣|grep download_file|awk '{print $1}'`

echo "刘欣 $e $f $g $h"

linux统计后缀名为bak的文件个数及文件大小geshu=`ls /data/datasource/testtxt | wc -l` daxiao=`du -sh /data/datasource/testtxt`。

如果文件数量不那么多可以使用du -m 20130606 | awk '{c+=$1}END{print c}'这两个命令显示的单位是MB,如果要显示GB可以print c 的c再除以一个1024。

优点:

1、Linux由众多微内核组成,其源代码完全开源。

2、Linux继承了Unix的特性,具有非常强大的网络功能,其支持所有的因特网协议,包括TCP/IPv4、TCP/IPv6和链路层拓扑程序等,且可以利用Unix的网络特性开发出新的协议栈。

3、Linux系统工具链完整,简单 *** 作就可以配置出合适的开发环境,可以简化开发过程,减少开发中仿真工具的障碍,使系统具有较强的移植性。

总结了一下有六种方法:现在有一个a文件,共有55行第一种:# awk '{print NR}' a|tail -n1第二种: # awk 'END{print NR}' a第三种: # grep -n "" a|awk -F: '{print '}|tail -n1第四种:# sed -n '$=' a第五种 # wc -l a|awk '{print }'第六种 #cat a |wc -l用Linux的wc命令在Linux下用wc进行计数。返回文件的行数、字数、字节数等。看个例子:wc wc1txt3 5 16 wc1txt输出信息依次是:行数 字数 字节数 文件名称。再具体点,单个统计。wc -m filename:显示一个文件的字符数wc -l filename:显示一个文件的行数wc -L filename:显示一个文件中的最长行的长度wc -w filename:显示一个文件的字数需要留意的:貌似wc统计的行算是用换行符来确定的。就是说最后一行要有换行符,最后wc的行数才是正确的,否则将会少一行。为了说明这个问题,看一个perl的测试:

linux awk命令怎么用? awk:用于一行中分成数个“栏位”来处理。适合处理 小型资料。

执行模式:awk '条件型别1{动作1} 条件型别2{动作2} ' filename

# last | awk '{print $1 "\t" $3}' <== 检视登入者的资料,只显示登入名和ip地址,并以[tab]隔开

awk 的内建变数

变数名称 代表的含义

NF 每一行($0)拥有的栏位总数

NR 当前 awk 所处理的是 “第几行” 资料

FS 当前分隔符,预设空格键

awk 的逻辑运算子

运算单元 代表含义

> 大于

< 小于

>= 大于或等于

<= 小于或等于

== 等于

!= 不等于

范例:

cat /etc/passwd | awk '{FS=":"} $3 < 10 {print $1 "\t" $3}' <== 档案/etc/passwd是以":"分隔的,检视第三栏小于10的资料,并且只显示帐号与第三栏

以上是我对awk的总结,希望对你有帮助,是我写的哦,不是复制的。

linux 怎么用awk命令 取出一段文字

awk '/<DIMENSION NAME="CCCCCC" SRC_TYPE="INTERNAL">/,/<DIMENSIONS>/ {print $0}' filename

Linux awk命令问题

head -n 3 /etc/passwd|awk -F ':' '$1="root"' 这里$1="root",表示将第1列的值赋值为root,因此上述命令表示:将/etc/passwd中前3行按照‘:’分隔后第一列以root显示,并列印其他列。

awk -F ':' '$3=="0"' /etc/passwd

这里$3=="0",表示将第三列与"0”进行匹配,以什么方式匹配呢?以‘:’分隔后的第三列进行匹配并列印。这里是匹配列印,所以列印的是匹配的那一行(被:分隔后),而不是显示分隔后的列。

所以,区别在于一个是分隔后赋值列印分隔后列的值,一个是按照指定分隔方式进行匹配找到匹配的行,列印的是匹配的那一行。

linux的awk命令问题

一行里 第一个元素和第三个元素

linux下 awk命令问题

1、其实这样基本满足要求。但是确实不够严谨。试试是否可以。

ps -le | grep sshd | awk '{print $4}'

2、对ps 命令用的最多的是ps -ef 对el 我不是很了解具体输出什么。当然,是不是你压根就没有这个sshd服务启动。这些都先验证一下。一步一步的输出,看看问题出现在管道的哪一个环节。

3、或者这个 $14==sshd 栏位你指定错了。 awk $指定的变数是从1 开始的。$0是整个行。这个不要忘记了哦。

如果上述1第一种情况可以输出,第二种2不可以话,可能就验证了我的假设。你栏位拆解出现错误。把$14 这个栏位好好看看。

linux awk命令基础 怎么在终端写

awk一般用于文字处理,通常用作资料提取。终端书写demo

awk '{print }' infotxt

以上是输出文字档案infotxt的所有内容,请使用实际档案进行替换infotxt

ps -ef|grep process_name | awk -F"" '{print $2}'

以上是查询process_name程序的ID资讯,把查询资讯作为引数传给awk进行过滤,请使用实际程序名替换process_name。

awk命令在 linux和aix下的区别

三种呼叫awk的命令方式:

1命令列方式:awk [-F field-separator] 'mands' input-file(s)

-F选项可选:awk -F: 'mands' input-file

2将所有的awk命令插入一个档案,并是awk程式可执行,然后用awk命令直译器作为指令码的首行,

以便通过键入指令码名称来呼叫它。

3将所有的awk命令插入一个单独档案,然后呼叫:

awk -f awk-script-file input-files(s)

-f:指明在档案awk-script-file中的awk指令码

input-file(s):使用awk进行浏览的档名。

awk指令码

在命令中呼叫awk时,awk指令码由各种 *** 作和模式组成。

-F,awk每次读一条记录或一行,并使用指定的分隔符分分隔指定域;

所没分隔符,则使用空格。

任何awk语句都由模式和动作组成

模式,决定动作语句何时触发及触发事件,若忽略模式部分,动作将时刻保持执行状态。

模式,可是任何条件语句,或符合语句,或正则表示式。

BEGIN:设定计数,列印头,在任何文字浏览动作之前;

END:用来在awk完成档案浏览动作后列印输出档案总数和结尾状态标志。

动作,在{}内指定;大多用来列印;里面可包含:if,looping,回圈推出结构;

若不指明采取动作,awk将列印所有浏览出来的记录。

如何在Linux中使用awk命令

awk例项

1、cat /etc/passwd|awk -F: '{print $1}'

2、linux的awk一般都是gawk,/bin/awk -> gawk

3、awk ‘/abc/’ filetxt 显示档案中包含abc行。类似grep abc atxt

4、awk ‘{print NR,NF,$1,$NF,}’ filetxt按空格分隔列,显示当前记录号、域数和每一行的第一列和最后一列。

-F引数可以设定分割引数,例如按:分割

awk -F: ‘{print $1}’ /etc/passwd

或者cat file|awk -F “|” ‘{print $1}’

5、awk程式语言

cat vtxt|awk ‘{print length($1)}’

6、awk中使用NR和FNR,一般在awk处理多个档案时,NR==FNR才有意义

NF 当前记录中的栏位数。

NR 当前记录数。

FNR同NR,但相对于当前档案。

awk ‘{print NR,FNR}’ testtxt test2txt

awk ‘{if(NR==FNR){a[FNR]=$1;}else{print $1,a[FNR]}}’ btxt atxt

7、列印奇数行与偶数行

awk ‘NR%2’ testtxt

awk ‘!(NR%2)’ testtxt

8、杀死tomcat的ssh指令码

#!/bin/sh

ps -ef| grep tomcat |grep -v grep | awk ‘{print $2}’ |xargs kill -9

9、列印前7列

cat atxt|awk ‘{NF=7}1’ >> btxt

tail -f aesslog|awk ‘NF=7′ OFS=’\t’ >> btxt

cut -d”,” -f3-6 urfile

LINUX系统怎么使用awk命令实现下述 *** 作

cat file|awk -F"name=" '{print $2}'|awk -F\" '{print $1}'

试试看,第二个”的转义,我没测试,可以自己调下

awk '{if (NR < 20){for (i=2; i<18; i++){sum += $i;}}else{exit;}} END{printf "Total:%x\n", sum; }' $file

$file是你的文件名

1、首先我们要知道怎么查看目录下文件,ls 这个命令就可以;但是在虚拟机中无法直接通过 ls 这个命令直接看出 文件 是 目录还是 问价(linux 的文件 系统划分 需要掌握)。

2、我们就需要 ls 的拓展命令 ls-l (可以直接用 ll 这样的简化命令,更多的可以自己查相关资料,命令的相关资料太多了);这里我们就可直接看出 文件 的类型; 标出的信息开头 ‘-’就是 文件命令中用 f 表示; ‘d’就是目录,命令中就用‘d’表示。

3、然后我们开始进行如何统计;find 这个命令可以查找文件;通过 find  /tmp/  -name 文件名,找出来。

4、然后我们通过扩展 命令 :find -type f(找出 文件类型是 f 的文件)我们可以看出 这个命令效果。

5、然后我们 通过 wc -l 这个命名进行统计;但两个命令需要一起使用, 这个时候通过管道符 “ | ”链接;命令就是:find -type f |wc -l;我们就可以实现 统计文件个数。

6、同理如果想要统计 目录 ,使用如图命令:find -type d|wc -l;默认会统计 隐藏的 文件或者 目录;所以显示的是 3。

7、隐藏文件或者目录是 ‘’开头的,所以我们排除它,就可以只统计出显示的文件。

以上就是关于linux shell 如何统计文件全部的内容,包括:linux shell 如何统计文件、linux统计后缀名为.bak的文件个数及文件大小、Linux bash 怎样取得文件行数等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/9724228.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-01
下一篇 2023-05-01

发表评论

登录后才能评论

评论列表(0条)

保存