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 删除空行。

你可能感兴趣的:(linux语言)