linux语言
一、目录
/:代表着根目录,是树形结构的最上层
.:表示当前目录,也可以用./表示;
. .:表示上一级目录,也可以用. ./表示;
~:代表用户自己的家目录;
二、常用命令
sed 替换
vim 文本编辑器
- 查找:/ abc 然后 回车; 调到下一个abc:小写n,上一个:大写N
- 每次翻一整页
向上翻整页 ctrl+f “f” meaning forward
向下翻整页 ctrl+b “b” meaning backward - 每次翻半页
向上翻半页 ctrl+u “u” meaning up
向下翻半页 ctrl+d “d” meaning down - 每次翻一行
向上翻一行 ctrl+y “y”meaning yield
向下翻一行 ctrl+e e meaning earser - 光标定位快捷键
将光标定位到屏幕顶部 zt
将光标定位到屏幕中间 zz
将光标定位到屏幕底部 zb
三、linux数值比较和字符串比较:
https://www.cnblogs.com/good-study/p/11112919.html
-ne 整数的不等于
!= 字符串的不等于
- 字符串截取:${varible:n1:n2}:截取变量varible从n1位置起(位置编号从0开始),截取长度为n2的字符串。
如:
begin_day=20200514
echo "overseas_server_cost_${begin_day:4:4}.txt"
输出:overseas_server_cost_0514.txt
四、查找文件位置
1、whereis <程序名称> ------ 不是太好用
2、locate <文件名称>
3、find -name <表达式> 根据文件名查找文件
一些例子:
从文件内容查找匹配指定字符串的行:
$ grep "被查找的字符串" 文件名
从文件内容查找与正则表达式匹配的行:
$ grep –e “正则表达式” 文件名
查找时不区分大小写:
$ grep –i "被查找的字符串" 文件名
从根目录开始查找所有扩展名为.log的文本文件,并找出包含”ERROR”的行
find / -type f -name "*.log" | xargs grep "ERROR"
系统查找到httpd.conf文件后即时在屏幕上显示httpd.conf文件信息。
find/-name"httpd.conf"-ls
在根目录下查找某个文件
find . -name "test"
在某个目录下查找包含某个字符串的文件
grep -r "zh_CN" ./
五、字符串操作
1、判断读取字符串值
表达式 | 含义 |
---|---|
${var} | 变量var的值, 与$var相同 |
${var-DEFAULT} | 如果var没有被声明, 那么就以$DEFAULT作为其值 * |
${var:-DEFAULT} | 如果var没有被声明, 或者其值为空, 那么就以$DEFAULT作为其值 * |
${var=DEFAULT} | 如果var没有被声明, 那么就以$DEFAULT作为其值 * |
${var:=DEFAULT} | 如果var没有被声明, 或者其值为空, 那么就以$DEFAULT作为其值 * |
${var+OTHER} | 如果var声明了, 那么其值就是$OTHER, 否则就为null字符串 |
${var:+OTHER} | 如果var被设置了, 那么其值就是$OTHER, 否则就为null字符串 |
${var?ERR_MSG} | 如果var没被声明, 那么就打印$ERR_MSG * |
${var:?ERR_MSG} | 如果var没被设置, 那么就打印$ERR_MSG * |
${!varprefix*} | 匹配之前所有以varprefix开头进行声明的变量 |
${!varprefix@} | 匹配之前所有以varprefix开头进行声明的变量 |
2、字符串操作(长度,读取,替换)
表达式 | 含义 |
---|---|
${#string} | $string的长度 |
${string:position} | 在position开始提取子串 |
${string:position:length} | 在position开始提取长度为$length的子串 |
${string#substring} | 从变量substring的子串 |
${string##substring} | 从变量substring的子串 |
${string%substring} | 从变量substring的子串 |
${string%%substring} | 从变量substring的子串 |
${string/substring/replacement} | 使用substring |
${string//substring/replacement} | 使用substring |
${string/#substring/replacement} | 如果substring, 那么就用substring |
${string/%substring/replacement} | 如果substring, 那么就用substring |
说明:"* $substring”可以是一个正则表达式.
示例: 示例.png参考链接:https://www.cnblogs.com/lukelook/p/11146548.html
六、数字运算
- 数字->整型
a = 1.3
方法如下:
speed = `echo ${a} | bc`
speed = `echo ${a} | cut -f1 -d"."`
speed = `echo ${a%%.*}`
speed = `echo ${a} | awk -F"." '{print $1}'`
speed = `echo ${a} | sed "s/\..*$//"` - 数字运算
【法1】
num1=20
num2=5
echo $(( num1 + num2 ))
echo $(( num1 - num2 ))
echo $(( num1 * num2 ))
echo $(( num1 / num2 ))
echo $(( num1 % num2 ))
【法2】
s=$[s+t] #结果相加
t=$[$1**2] #求x的平方
t=$[t*4] #结果乘以4
s=$[s+t] #结果相加
法1,法2均不支持小数,否则报错如下:
syntax error: invalid arithmetic operator (error token is ".5")
小数计算方式:bc命令
【例1】
num1=20.5
num2=5
echo "$num1 + $num2" | bc
echo "$num1 - $num2" | bc
echo "$num1 * $num2" | bc
echo "$num1 / $num2" | bc
echo "$num1 % $num2" | bc
【例2】
limit_num=`echo "${limit_num_}*1.5/1" | bc`
注:/1是为了取整
七、字符串->数组
- 与/之间与分割的字符 ,另外/后有一个空格不可省略
str=${str//,/ }; - 默认情况下,bash shell会将下面的字符当做字段分隔符:空格、制表符、换行符。
str=${str// / };
str="192.168.31.65"
array=(${str//\./ })
for i in "${!array[@]}"; do
echo "$i=>${array[i]}"
done
分隔后的全部数组
${arr[@]}
分隔后的每一项
${arr[0]} ${arr[1]} ...
分割后的数组长度
${#arr[@]}
存储整个索引值
${!arr[@]}
注意:shell命令,=前后不能有空格!
八、for循环
for i in "file1" “file2” “file3”
do
xxxxxx
done
九、mysql导出csv
mysql -A ${db} -h ${host} -P ${port} -u${user} -p${pwd} -ss -e "${sql}" | sed 's/\t/","/g;s/^/"/;s/$/"/;s/\n//g' > ${file_dir}/${file_name}.csv
- 上述sed命令,是因为mysql直接导出的文件(txt or csv),都是用 \t 分割的,想用csv打开,所以把 \t 替换成 ,
1、s/$// 在每一行后面追加空。
2、s为搜索。
如:s/a/b/
搜索a将替换为b ,并只替换一次。
3、s/ *//g 将空格删除。
4、g代表搜索到的全部替换 。
5、“空格星”( " *") 代理多个空格。
6、/^$/d 删除空行。