Python命令行参数sys.argv[]
学习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,这里也可以多带几个参数,程序会先后输出参数文件内容。
1 #coding:utf-8 2 ''' 3 Created on 2015年8月10日 4 5 @author: yj 6 ''' 7 import sys 8 def skip_header(r): 9 '''Skip the reader in reader r,and return the first real piece of data.''' 10 #Read the description line and then the comment lines.读取描述和注释行 11 line =r.readline() 12 print line 13 while line.startswith('#'): 14 line=r.readline() #跳到下一行 15 #Now line contains the first raal piece of data. 16 return line 17 def process_file(r): 18 '''Read and print open reader r.''' 19 #Find and print piece of data. 20 line=skip_header(r).strip() 21 print line 22 #Read the rest of the data. 23 for line in r: 24 line=line.strip() 25 print line 26 if __name__=="__main__": 27 print "start" 28 input_file=open(sys.argv[1],'r') 29 process_file(input_file) 30 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、按照某个字符分割如“."
1 str = 'www.baidu.com' 2 #这里的str.split('.')的到的是新的字符串,并不影响原来的str字符串 3 str1 = str.split('.') 4 5 print str1 6 print str 7 8 #结果为['www','baidu','com'] 'www.baidu.com'
b、按某一个字符分割,且分割n次。如按‘.’分割1次
1 str = ('www.google.com') 2 print str 3 str_split = str.split('.',1) 4 print str_split 5 #结果:['www','google.com']
c、按某一字符(或字符串)分割,且分割n次,并将分割的完成的字符串(或字符)赋给新的(n+1)个变量。(注:见开头说明)
如:按‘.’分割字符,且分割1次,并将分割后的字符串分别赋给2个变量str1,str2
1 url = ('www.google.com') 2 str1, str2 = url.split('.', 1) 3 print str1 4 print str2 5 6 #结果为:str1:www str2:google.com