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} decode以后
{"name":"绉﹁秴閫?,"age":18} encode以后
{u'age': 18, u'name': u'\u79e6\u8d85\u9038'} loads出来


全是在一些琐碎的杂事上花功夫,有什么用?

有这个闲心,还不如去看两本书。

你可能感兴趣的:(Python)