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借助什么库吗?
回答:
$ 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 ~]$ pythonPython 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啦啦啦
以上是 shell脚本中如何高效的encode一个字符串 的全部内容, 来源链接: utcz.com/a/162270.html