48个shell小技巧

作者: SkTj | 来源:发表于2019-01-31 14:57 被阅读145次

    调试
    x.sh -xv
    [[ -f xx ]]||touch xx
    [[ -s file ]]{string//pattern/replacement}
    a='a,b,c'
    echo ${a//,/ /}

    1. Contains 子字符串?
      string="My string"
      if [[ string == *My* ]]; then echo "It's there!" fi rename .shs .sh *.shs while read line ; do echoline; done < a.txt
      cat a.txt | sed -e '/^$/d'
      比较文件的修改时间
      [[ file1.txt -nt file2.txt ]] && echo true || echo false
      [[ file1.txt -ot file2.txt ]] && echo true || echo false

    去掉第二列
    cut -f 1,3-
    把输出保存到变量里
    a=( (echo 'out'; echo 'error' 1>&2) 2>&1 1>/dev/null)
    echoa
    error
    cat a.txt | sed 1,3d 遍历数组 array=( one two three ) for i in{array[@]}
    do
    echo i done du -sh cat /proc/cpuinfo / date +%Y-%m-%d
    2012-12-24
    date +%Y-%m-%d –date ‘-1 day' 2012-12-23 date +%Y-m-%d –date ‘Dec 25'
    2011-12-25
    date +%Y-m-%d –date ‘Dec 25 – 10 days' 2011-12-15 dirname 获取路径 basename 获取文件名 复杂分隔符 echo "a||b||c||d" | awk -F '[|][|]' '{print3}'
    多种分隔符
    echo "a||b,#c d" | awk -F '[| ,#]+' '{print4}'
    echo "a||b##c|#d" | awk -F '([|][|])|([#][#])' '{printNF}'
    echo RANDOM var=hack.fun.book.txt echo{var%.}
    hack.fun.book
    echo {var%%.*} hack echo{var#.
    }
    fun.book.txt
    echo {var##.*} txt 执行上一条命令!! python -m SimpleHTTPServer cp filename{,.bak} find . -type f -size 0 -delete ifconfig eth0 |grep "inet addr:" |awk '{print2}'|cut -c 6-
    清除僵死进程
    ps -eal | awk '{ if (2 == "Z"){ print4}}' | kill -9
    打印奇数行
    awk 'NR%2' file
    打印奇数行,偶数行
    sed -n "0~2p" 1.sh
    sed -n "1~2p" 1.sh
    cat file | grep -A100 string
    cat file | grep -B100 string #前面
    cat file | grep -C100 string #前后
    sed -n '/string/,+100p'
    awk '/string/{f=100}--f>=0'
    //////常用正则表达式
    匹配中文字符的正则表达式:[u4e00-u9fa5]
    评注:匹配中文还真是个头疼的事,有了这个表达式就好办了
    匹配双字节字符(包括汉字在内):[^x00-xff]
    评注:可以用来计算字符串的长度(一个双字节字符长度计2,ASCII字符计1)
    匹配空白行的正则表达式:^ 评注:可以用来删除空白行 匹配HTML标记的正则表达式:<(S*?)[^>]*>.*?</1>|<.*? /> 评注:网上流传的版本太糟糕,上面这个也仅仅能匹配部分,对于复杂的嵌套标记依旧无能为力 匹配首尾空白字符的正则表达式:^s*|s*
    评注:可以用来删除行首行尾的空白字符(包括空格、制表符、换页符等等),非常有用的表达式
    匹配Email地址的正则表达式:w+([-+.]w+)
    @w+([-.]w+).w+([-.]w+)
    评注:表单验证时很实用
    匹配网址URL的正则表达式:[a-zA-z]+://[^s]*
    评注:网上流传的版本功能很有限,上面这个基本可以满足需求
    匹配帐号是否合法(字母开头,允许5-16字节,允许字母数字下划线):^[a-zA-Z][a-zA-Z0-9_]{4,15}评注:表单验证时很实用 匹配国内电话号码:d{3}-d{8}|d{4}-d{7} 评注:匹配形式如0511-4405222或021-87888822 匹配腾讯QQ号:[1-9][0-9]{4,} 评注:腾讯QQ号从10000开始 匹配中国邮政编码:[1-9]d{5}(?!d) 评注:中国邮政编码为6位数字 匹配身份证:d{15}|d{18} 评注:中国的身份证为15位或18位 匹配ip地址:d+.d+.d+.d+ 评注:提取ip地址时有用 匹配特定数字: ^[1-9]d*  //匹配正整数
    ^-[1-9]d//匹配负整数 ^-?[1-9]d*  //匹配整数
    ^[1-9]d
    |0//匹配非负整数(正整数+ 0) ^-[1-9]d*|0  //匹配非正整数(负整数+ 0)
    ^[1-9]d.d|0.d[1-9]d//匹配正浮点数 ^-([1-9]d*.d*|0.d*[1-9]d*) //匹配负浮点数
    ^-?([1-9]d.d|0.d[1-9]d|0?.0+|0)//匹配浮点数 ^[1-9]d*.d*|0.d*[1-9]d*|0?.0+|0  //匹配非负浮点数(正浮点数+ 0)
    ^(-([1-9]d.d|0.d[1-9]d))|0?.0+|0//匹配非正浮点数(负浮点数+ 0) 评注:处理大量数据时有用,具体应用时注意修正 匹配特定字符串: ^[A-Za-z]+  //匹配由26个英文字母组成的字符串
    ^[A-Z]+//匹配由26个英文字母的大写组成的字符串 ^[a-z]+  //匹配由26个英文字母的小写组成的字符串
    ^[A-Za-z0-9]+//匹配由数字和26个英文字母组成的字符串 ^w+  //匹配由数字、26个英文字母或者下划线组成的字符串


    //生成10个随机数

    !/bin/bash

    for i in seq 1 10
    do
    name=echo $RANDOM|md5sum|cut -c1-10
    touch /tmp/tmp$name
    ls /tmp
    done

    function check_ip() {
    IP=1 if [[IP =~ ^[0-9]{1,3}.[0-9]{1,3}.[0-9]{1,3}.[0-9]{1,3}]]; then a1=(echo IP|awk -F. '{print1}')
    a2=(echoIP|awk -F. '{print 2}') a3=(echo IP|awk -F. '{print3}')
    a4=(echoIP|awk -F. '{print 4}') if [a1 -le 255 -a a2 -le 255 -aa3 -le 255 -a a4 -le 255 ] then echo "IPIP available."
    else
    echo "IP IP not available!" fi else echo "IP format error!" fi } read -p "Enter your IP:" ip check_ipip

    生成50以内的随机数
    echo ((RANDOM%50+1))

    cat /var/log/httpd/access.log|awk '{print $1}'|sort|uniq -c|sort -nr|head -n5

    netstat -na|grep ESTABLISHED|awk '{print5}'

    openssl rand -bash64 32

    date -d "3 days" +"%F"

    相关文章

      网友评论

        本文标题:48个shell小技巧

        本文链接:https://www.haomeiwen.com/subject/yfwksqtx.html