一、awk if分支结构
二、awk数组 for循环
一、awk if分支结构
案例1
awk过滤中的if分支结构
1)单分支
统计/etc/passwd文件中UID小于或等于1000的用户个数:
统计/etc/passwd文件中UID大于1000的用户个数:
统计/etc/passwd文件中登录Shell是“/bin/bash”的用户个数:
2)双分支
分别统计/etc/passwd文件中UID小于或等于1000、UID大于1000的用户个数:
分别统计/etc/passwd文件中登录Shell是“/bin/bash”、 登录Shell不是“/bin/bash”的用户个数:
二、awk数组
注意,awk数组的下标除了可以使用数字,也可以使用字符串,字符串需要使用双引号:
案例3:awk扩展应用
1)awk统计Web访问排名
在分析Web日志文件时,每条访问记录的第一列就是客户机的IP地址,其中会有很多重复的IP地址。因此只用awk提取出这一列是不够的,还需要统计重复记录的数量并且进行排序。
通过awk提取信息时,利用IP地址作为数组下标,每遇到一个重复值就将此数组元素递增1,最终就获得了这个IP地址出现的次数。
针对文本排序输出可以采用sort命令,相关的常见选项为-r、-n、-k。其中-n表示按数字顺序升序排列,而-r表示反序,-k可以指定按第几个字段来排序
实现此案例需要按照如下步骤进行。
步骤一:统计Web访问量排名
分步测试、验证效果如下所述。
1)提取IP地址及访问量
2)对第1)步的结果根据访问量排名
案例4:编写监控脚本
本案例要求编写脚本,实现计算机各个性能数据监控的功能,具体监控项目要求如下:
CPU负载
网卡流量
内存剩余容量
磁盘剩余容量
计算机账户数量
当前登录账户数量
计算机当前开启的进程数量
本机已安装的软件包数量
步骤
实现此案例需要按照如下步骤进行。
步骤一:准备工作
1)查看性能数据的命令
步骤二:编写参考脚本
1)脚本内容如下:
你这个代码里面有好几个错误的地方:
#include <stdio.h>#include <stdlib.h>
#include <malloc.h>
#include <math.h>
int main(void)
{
float result = 0
int *a
int N
int sum=0
float Avr = 0
int i,j
x:
scanf("%d", &N)
if(N>10000 && N<= 0)
goto x
a = (int *)malloc(N*sizeof(int))
for(i=0i<=N-1i++){
int temp=0
scanf("%d",&temp)
a[i]=temp
sum+=temp
}
printf("%d\n",a[1]+a[2])
printf("sum = %d\n", sum)//输出sum不需要加&,加上就变成地址了
Avr=(float)sum/N
printf("Avr =%f \n", Avr)//输出Avr不需要&,输出float应该用%f
for(j=0j<Nj++)
{
//这里不知道你要做什么,你的代码都是用的
//i做下标,但是循环的是j
//我这里和你的稍有不同,以示区别
result+=(a[j]-Avr)*(a[i]-Avr)
}
printf(" result=%f \n", result)//输出result不需要&,输出float应该用%f
result/=N
printf("%f\n",sqrt(result))//sqrt返回值是double型,输出应该用%f
free(a)
return 0
}
以下是我在linux上的测试截图,希望能帮到你:
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)