Python:读取命令行参数
也是argv之类的。
argv[0], argv[1], argv[2] ...
argv[0]是py文件的文件名
argv[1] - ... 是后面跟着的参数
import sys
args = sys.argv[:]
print args
输入 python test_param1.py 1 2 3 'a' "asdf" asdf
输出 ['test_param1.py', '1', '2', '3', "'a'", 'asdf', 'asdf']
对比结果就知道了。类型都变了。
如果想把命令传成JSON数据格式,在控制台上输入""应该是会被直接省略的……
想了个山寨的办法,用占位符,到了程序里面直接替换掉,再用json的loads
(为什么csdn的两个$要被读成换行+斜体……)
输入:
在代码里面,把 $$ 都替换成 ",就好了。
替换以后:{"name":"qcy","age":18}
代码调用json.loads()
输出:{u'age': 18, u'name': u'qcy'}
# -*- coding: utf-8 -*-
import json
import sys
args = sys.argv[1:]
json_str = args[0].replace('$$','"')
print json_str
params = json.loads(json_str)
print params
如果参数要传汉字进去,Python2真的很烦!!!!!!!!!!!!!!!!
import sys
args = sys.argv[1:]
json_str = args[0].replace('$$','"')
json_str = json_str.decode('gbk')
print json_str
params = json.loads(json_str)
print params
输入,输出
{"name":"秦超逸","age":18}
{u'age': 18, u'name': u'\u79e6\u8d85\u9038'}
关于python2编码的问题
# -*- coding: utf-8 -*-
import json
import sys
args = sys.argv[1:]
json_str = args[0].replace('$$','"')
print json_str
json_str = json_str.decode('gbk')
print json_str, type(json_str)
json_str = json_str.encode('utf-8') # 这句话可要可不要,json.loads都可以用。
print json_str, type(json_str)
params = json.loads(json_str)
print params
输入:
输出:
{"name":"秦超逸","age":18} # replace以后
{"name":"秦超逸","age":18} <type 'unicode'> decode以后
{"name":"绉﹁秴閫?,"age":18} <type 'str'> encode以后
{u'age': 18, u'name': u'\u79e6\u8d85\u9038'} loads出来
全是在一些琐碎的杂事上花功夫,有什么用?
有这个闲心,还不如去看两本书。
相关文章