Python命令行参数sys.argv[]

时间:2023-03-08 18:29:44

学习C语言的时候就没弄明白命令行参数的用法,在学习Pyton 的时候又遇到了命令行参数,在这里稍微学习了一下,稍微明白了一些在这里做个记录方便后面回顾复习。

Sys.argv[]是用来获取命令行参数的,sys.argv[0]表示代码文件绝对路径,所以所以其余参数从1开始,以下两个例子说明:

1、

import sys,os 
os.system(sys.argv[1])

这个例子os.system接收命令行参数,运行参数指令,保存为sample1.py,命令行带参数运行sample1.py notepad,将打开记事本程序。

2、这个例子是简明python教程上的,明白它之后你就明白sys.argv[]了。

1.    import sys
2. def readfile(filename): #从文件中读出文件内容 ,这是被调函数但被传参数为文件名de时候调用该函数
3. '''''Print a file to the standard output.'''
4. f = file(filename) #打开文件,这里和open效果一样
5. while True:
6. line = f.readline() #读取每行信息
7. if len(line) == 0:
8. break
9. print line, # notice comma 分别输出每行内容
10. f.close()
11. # Script starts from here 这里才是程序的入口,先判断是否有命令行参数传入小于二也就是没有命令行参数了
12. if len(sys.argv) < 2:
13. print 'No action specified.'
14. sys.exit()
15. if sys.argv[1].startswith('--'): #判断命令行参数是否是以--开始的,如果是则是相关命令的参数,如果不是就是文件名了
16. option = sys.argv[1][2:] #这是一个二维数组,把argv[1]这个参数的下标为[2]即第三个字符开始直到结束的字符串
                        #复制给option 如果是--help,则这之后option为help
17. # fetch sys.argv[1] but without the first two characters
18. if option == 'version': #当命令行参数为-- version,显示版本号
19. print 'Version 1.2'
20. elif option == 'help': #当命令行参数为--help时,显示相关帮助内容 及打印注释的相关内容
21. print '''''/
22. This program prints files to the standard output.
23. Any number of files can be specified.
24. Options include:
25. --version : Prints the version number
26. --help : Display this help'''
27. else: #否则打印不知道的命令
28. print 'Unknown option.'
29. sys.exit()
30. else: #如果命令行参数不是以--格式开始的,那么就是文件了所以执行西段代码
31. for filename in sys.argv[1:]: #当参数为文件名时,传入readfile,读出其内容
32. readfile(filename)

保存程序为sample.py.我们验证一下:

1)       命令行带参数运行:sample.py –-version  输出结果为:version 1.2

2)       命令行带参数运行:sample.py –-help  输出结果为:This program prints files……

3)       在与sample.py同一目录下,新建a.txt的记事本文件,内容为:test argv;命令行带参数运行:sample.py a.txt,输出结果为a.txt文件内容:test argv,这里也可以多带几个参数,程序会先后输出参数文件内容。

 #coding:utf-8
'''
Created on 2015年8月10日 @author: yj
'''
import sys
def skip_header(r):
'''Skip the reader in reader r,and return the first real piece of data.'''
#Read the description line and then the comment lines.读取描述和注释行
line =r.readline()
print line
while line.startswith('#'):
line=r.readline() #跳到下一行
#Now line contains the first raal piece of data.
return line
def process_file(r):
'''Read and print open reader r.'''
#Find and print piece of data.
line=skip_header(r).strip()
print line
#Read the rest of the data.
for line in r:
line=line.strip()
print line
if __name__=="__main__":
print "start"
input_file=open(sys.argv[1],'r')
process_file(input_file)
input_file.close()

3、上面的例子用到了一个函数startswith()

函数:startswith()

作用:判断字符串是否以指定字符或子字符串开头

一、函数说明
语法:string.startswith(str,
beg=0,end=len(string))
      或string[beg:end].startswith(str)
 
参数说明:
string: 
被检测的字符串
str: 
    指定的字符或者子字符串。(可以使用元组,会逐一匹配)
beg: 
  设置字符串检测的起始位置(可选)
end: 
  设置字符串检测的结束位置(可选)
如果存在参数
beg 和
end,则在指定范围内检查,否则在整个字符串中检查

返回值
如果检测到字符串,则返回True,否则返回False。默认空字符为True

函数解析:如果字符串string是以str开始,则返回True,否则返回False

实例:

s = 'hello good boy doiido'

print s.startswith('h')

print s.startswith('hel')

print s.startswith('h',4)

print s.startswith('go',6,8)
#匹配空字符集
print s.startswith('')
#匹配元组
print s.startswith(('t','b','h')) 常用环境:用于if判断
if s.startswith('hel'):
print "you are right"
else:
print "you are wrang"

4、上面的程序用到了strip()函数下面简单介绍一下

注意:strip()函数本身并不影响原来字符串的内容,得到的仅仅是一个新的字符串,与原来的字符串无关

函数原型

声明:s为字符串,rm为要删除的字符序列

s.strip(rm)        删除s字符串中开头、结尾处,位于 rm删除序列的字符

s.lstrip(rm)       删除s字符串中开头处,位于 rm删除序列的字符

s.rstrip(rm)      删除s字符串中结尾处,位于 rm删除序列的字符

注意:

a. rm为空时,默认删除空白符(包括'\n', '\r',  '\t',  ' ')

例如:

复制代码 代码如下:

>>> a = '     123'
>>> a.strip()
'123'
>>> a='\t\tabc'
'abc'
>>> a = 'sdff\r\n'
>>> a.strip()
'sdff'

b.这里的rm删除序列是只要边(开头或结尾)上的字符在删除序列内,就删除掉。

例如 :

复制代码 代码如下:

>>> a = '123abc'
>>> a.strip('21')
'3abc'   结果是一样的
>>> a.strip('12')
'3abc'

5、函数split()

说明:
Python中没有字符类型的说法,只有字符串,这里所说的字符就是只包含一个字符的字符串!!!
这里这样写的原因只是为了方便理解,仅此而已。

a、按照某个字符分割如“."

 str = 'www.baidu.com'
#这里的str.split('.')的到的是新的字符串,并不影响原来的str字符串
str1 = str.split('.') print str1
print str #结果为['www','baidu','com'] 'www.baidu.com'

b、按某一个字符分割,且分割n次。如按‘.’分割1次

 str = ('www.google.com')
print str
str_split = str.split('.',1)
print str_split
#结果:['www','google.com']

c、按某一字符(或字符串)分割,且分割n次,并将分割的完成的字符串(或字符)赋给新的(n+1)个变量。(注:见开头说明)

如:按‘.’分割字符,且分割1次,并将分割后的字符串分别赋给2个变量str1,str2

 url = ('www.google.com')
str1, str2 = url.split('.', 1)
print str1
print str2 #结果为:str1:www str2:google.com