shell脚本中如何高效的encode一个字符串

`

function urlencode() {
    local length="${#1}"
    for (( i = 0; i < length; i++ )); do
        local c="${1:i:1}"
        case $c in
            [a-zA-Z0-9.~_-]) printf "$c" ;;
            *) printf "$c" | xxd -p -c1 | while read x;do printf "%%%s" "$x";done
        esac
    done
}

`
目前是用这个函数encode的,效率特别低,100多k的文件都encode很久,请问如何encode快一些,可以在shell借助什么库吗?

阅读 4.9k
3 个回答
$ alias urldecode='python -c "import sys, urllib as ul; \
    print ul.unquote_plus(sys.argv[1])"'

$ alias urlencode='python -c "import sys, urllib as ul; \
    print ul.quote_plus(sys.argv[1])"'

$ urlencode 'lalala啦啦啦'
lalala%E5%95%A6%E5%95%A6%E5%95%A6

$ urldecode 'alala%E5%95%A6%E5%95%A6%E5%95%A6'
alala啦啦啦

参考: https://www.cnblogs.com/Bob-w...

不知道你编码的具体用途。

若是 HTTP 请求,则不可能用在请求头,因你提到 100KB 的文件。那么猜测应该是请求体(body),这种情况可以用 curl 命令,如

curl --data-urlencode 'content@somefile.bin' http://localhost/

这会上传文件 somefile.bin,自动做 url 编码。

参考 man curl

@Yujiaao
你的写法应该是python2的写法

我这里是python3的写法

[jian@laptop ~]$ python
Python 3.6.7 (default, Mar 21 2019, 20:23:57) 
[GCC 8.3.1 20190223 (Red Hat 8.3.1-2)] on linux
Type "help", "copyright", "credits" or "license" for more information.
>>> 


[jian@laptop ~]$ alias urlencode='python -c "import sys, urllib.parse as ul; \
    print (ul.quote(sys.argv[1]))"'
[jian@laptop ~]$ urlencode 'lalala啦啦啦'
lalala%E5%95%A6%E5%95%A6%E5%95%A6
[jian@laptop ~]$ alias urldecode='python -c "import sys, urllib.parse as ul; \
    print (ul.unquote(sys.argv[1]))"'
[jian@laptop ~]$ urldecode 'alala%E5%95%A6%E5%95%A6%E5%95%A6'
alala啦啦啦


撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题
宣传栏