首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

赛选日志中的数字,进行数字求和shell脚本.sh-shell

#!/bin/bash fenzujs(){ # 定义一个函数为:fenzujs格式:fenzujs(){ } catfile="22.txt" catip="192.168.146" # 定义ip段 for((i=21; i<=37 ; i++ )) do echo "正在过滤IP:$catip.$i 过滤出来的信息为:" # 打印catip 和循环中的数值 cat $catfile | grep -A 3 "$catip.$i" | grep -v -E "ok=2|changed|TASK" # 查看日志文件,符号 | 管道进行过滤 # grep -A -3 配合内容的后3行的内容,有三行数据 # grep -v 不匹配 -E 多个内容 # grep -5 打印匹配行的前后5行 # grep -C 5 打印匹配行的前后5行 # grep -A 5 打印匹配行的后5行 # grep -B 5 打印匹配行的前5行 zuo=( `cat $catfile | grep -A 3 "$catip.$i" | grep -v -E "ok=2|changed|TASK" | grep "|" | awk -F"|" '{print $1}' | sed "s/\"//g"` ) # 定义zuo数组变量 # awk -F"|" 过滤出来的内容,用 | 这个为间隔符号,print 第1列,sed s///g 将 冒号进行替换为空, 特殊字符转译 \ 冒号为普通字符 echo "IP信息段落中左边数值为:${zuo[*]}" you=( `cat $catfile | grep -A 3 "$catip.$i" | grep -v -E "ok=2|changed|TASK" | grep "|" | awk -F"|" '{print $2}' | sed "s/\"//g"` ) echo "IP信息段落中右边数值为:${you[*]}" calculatezuo=$(echo ${zuo[*]} | sed "s/ /+/g") ; echo "IP: $catip.$i 左边数组:$calculatezuo 总值为:" $[$calculatezuo] calculateyou=$(echo ${you[*]} | sed "s/ /+/g") ; echo "IP: $catip.$i 左边数组:$calculateyou 总值为:" $[$calculateyou] # 定义变量:calculatezuo 为一个执行结果:打印数组,将空格替换为 + 符号,

00

python format函数

在Python 3.0中,%操作符通过一个更强的格式化方法format()进行了增强。对str.format()的支持已经被反向移植到了Python 2.6 在2.6中,8-bit字符串和Unicode字符串都有一个format()方法,这个方法会把字符串当作一个模版,通过传入的参数进行格式化。这个用来格式化的模版使用大括号({,})作为特殊字符。 # Substitute positional argument 0 into the string. "User ID: {0}".format("root") -> "User ID: root" # Use the named keyword arguments  'User ID: {uid} Last seen: {last_login}'.format(   uid='root',   last_login = '5 Mar 2008 07:20') ->  'User ID: root Last seen: 5 Mar 2008 07:20' 大括号可以写两遍来转义。 format("Empty dict: {{}}") -> "Empty dict: {}" 字段名字可以为整数,表示参数的位置。像{0}, {1}等。也可以是参数的名字。你以可以使用字段的组合来读取属性或者字典的key值。 import sys 'Platform: {0.platform}\nPython version: {0.version}'.format(sys) ->  'Platform: darwin\n  Python version: 2.6a1+ (trunk:61261M, Mar 5 2008, 20:29:41) \n  [GCC 4.0.1 (Apple Computer, Inc. build 5367)]' import mimetypes  'Content-type: {0[.mp4]}'.format(mimetypes.types_map) ->  'Content-type: video/mp4' 注意,当使用字典类型的表示方法,如[.mp4]时,你不需要引号将字符串(.mp4)引起来;它会查找用.mp4作为主键的值。以整数开头的字符串会被转换成一个整数。你不能在被格式化的字符串中写复杂的表达式。 到此,我们已经演示了怎样替换指定的字段。我们还可以通过在格式化指示符后面添加一个冒号来进行精确格式化。例如: # Field 0: left justify, pad to 15 characters # Field 1: right justify, pad to 6 characters fmt = '{0:15} ${1:>6}' fmt.format('Registration', 35) ->  'Registration $ 35' fmt.format('Tutorial', 50) ->  'Tutorial $ 50' fmt.format('Banquet', 125) ->  'Banquet $ 125' 格式化指示符可以通过嵌套进行引用。 fmt = '{0:{1}}' width = 15 fmt.format('Invoice #1234', width) ->  'Invoice #1234 ' width = 35 fmt.format('Invoice #1234', width) ->  'Invoice #1234 ' 可以指定所需长度的字符串的对齐方式。 效果字符: < (默认)左对齐 > 右对齐 ^ 中间对齐 = (只用于数字)在小数点后进行补齐 格式化指示符可以包含一个展示类型来控制格式。例如,浮点数可以被格式化为一般格式或用幂来表示。 >>> '{0:g}'.format(3.75)  '3.75' >>> '{0:e}'.format(3.75)  '3.750000e+00' 展示类型有很多。2.6的文档里有完整的列表。这里列出一些示例。 'b' - 二进制。将数字以2为基数进行输出。 'c' - 字符。在打印之前将整数转换成对应的Unicode字符串。 'd' - 十进制整数。将数字以10为基数进行输出。 'o' - 八进制。将数字以8为基数进行输出。 'x' - 十六进制。将数字以16为基数进行输出,9以上的位数用小写字母。 'e' - 幂符号。用科学计数法打印数字。用'e'表示幂。 'g' - 一般格式。将数值以fixed-point格式输出。当数值特别大的时候,用幂形式打印。 'n' - 数字。当值为整数时和'd'相同,值为浮点数时和'g'相同。不同的是它会根据区域设置插入数字分隔符。 '%' - 百分数。将数值乘以100然后以fixed-point

02

【C语言】char 关键字

④ char  ⇿ 字符型 ⒈描述 ⇨ char 字符型变量是用来存储字符常量的变量,字符型变量在内存空间所占字节大小为1个字节,%c 所对应的是打印字符的格式数据,有符号(signed)的char取值范围是『 (负)128 ~ 127』无符号字符unsigned char的取值范围是『0~255』 ⒉作用 ⇨ 定义一个字符型变量的方法是使用关键字 char,例如: char str = 'A'; ⒊注意 ⇨ 字符数据在内存中存储的是字符的 ASCll 码,即使是一个无符号整数,其形式与整数的存储形式一样,因为在C语言的字符型数据与整形数据之间通用。 ⒋实际上字符型是被称之为整形字符类型('单引号')如果不相信的话,你可以用sizeof关键字求下单引号字面值、常量看下它所在的字节大小是不是一个整形(④字节)的。 ⒌拓展知识点 ⇨ 相信学习过C++语言的小伙伴应该知道在C++语言当中它还是一个字节的。

01
领券