十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
print语句print [expression ("," expression)* [","]]print expression [("," expression)+ [","]][]表示可选项,*表示零次或多次重复,+表示至少一次重复。print是一种特殊的语句,它用于在stdout输出字符串。print有多种使用形式:print xprint x,yprint x,y,print object, x, y第1行是print的最普通的形式。第2行用print一次输出多个变量值,print会在变量之间自动加上一个"空格"。第3行与第2行的不同是在y的后面多了一个",",这个逗号用来阻止print在打印出x和y的值后,自动附加上一个“\n”字符。第4行,是一种输出重定向的形式,也就是说把x和y的值输出到object的write方法中,这同时也表明object必须有一个write方法。在python中,print语句其实只是一种简写形式,是下面这段程序的简写:import syssys.stdout.write(str(x) + '\n')上面这两行合起来就是“print x”这一句。可以看出,print是调用str()函数来产生字符串的,并且会在输出的字符串后加上一个'\n'字符。由于print实际是上调用了stdout的write方法。程序员也可以把stdout赋为别的值,从面实现print的输出重定向的功能。比如:import sysx="I'm here!"fp=file('log.txt','a')sys.stdout=fpprint x第4行改变了stdou的值,而且fp也是一个文件对象,有一个write方法。这一小段代码的功能是把print的输出全部以appand的模式写到了文件log.txt中。在第4行之后的print语句,都是这种功能。现在假设要恢复print输出到标准输出的功能,那么就需要让stdout重新指向标准输出,可以使用如下的方式:sys.stdout=sys.__stdout__在sys.__stdout__中保存有指向标准输出的信息,通过这行代码,print可以恢复为原来的功能。有时候要在这两种模式之间换来换去,一会要输出到文件中,一会要输出到标准输出中,通过改变sys.stdout的值可以实现,不过太麻烦,python提供了另外一种简便的print语句形式,来解决这种需求:print object,x,y能过这个符号,可以实现输出重定向到object,当然object必须有一个write方法。否则会出现AttributeError。注意,在这种print形式中,sys.stdout并没有改变,也就是说在这之后的print语句,具有的还是标准功能。虽然print语句实际上sys.stdou.write(),但sys模块的import工作并不需要程序员操心,python会自动处理。类似于print的输出,当用内置函数raw_input([prompt])进行读取操作时,实际上用的是sys.stdin.read()方法。也可以通过改变stdin的值来控制入操作。相应的也有一个sys.__stdin__用来保存标准输入的信息。
我们拥有10多年网页设计和网站建设经验,从网站策划到网站制作,我们的网页设计师为您提供的解决方案。为企业提供做网站、网站建设、微信开发、重庆小程序开发、移动网站建设、HTML5、等业务。无论您有什么样的网站设计或者设计方案要求,我们都将富于创造性的提供专业设计服务并满足您的需求。
题主你好,
一般来说, python函数中有两种形式的参数: 位置参数, 关键字参数.
位置参数: 说白了就是在函数调用时必传的,你不给它赋值函数就运行不了.如:
从拿上图例子来说, 在调用hello时,如果你只写个hello(),肯定会报错, 因为在执行函数里面的print(name)时, 不知道name的值是多少.
所以对于上图来说,hello("Jack"), hello("Mike")这都是正确的调法.
小结: 就上面的hello函数定义来说, name就叫做位置参数. 说白了就是函数定义中,只有变量名的参数就是位置参数(如果这句话不理解,接着向下看完关键字参数,一比较就明白了),而位置参数的特点是: 调用函数时必须要给它们传值,原因上面已经说过 //def hello(a,b,c,d,e,f) 这里面a,b,c,d,e,f全都是位置参数
-----
关键字参数: 首先它同位置参数一样, 也是用在函数定义中. 其外在表现就是一具等式: "变量名=值". 举例来说吧:
对比一下这个hello函数, 和位置参数中的hello函数有啥不一样,可以看到该hello函数中的参数为 name="张三",而位置参数中的hello函数参数为 name, 最大的区别在于函数调用时,
位置参数中你要使用 hello("名字")的形式进行调用, 而关键字参数中直接使用hello()不用加任何参数. 原因也很好理解: 位置参数中name没有默认值, 而关键字参数中,在声明的时候就给name赋了一个默认值,"张三", 所以说在调用关键字参数中的hello函数时,即使我们不给name参数传值,print(name)函数在执行时会使用name的默认值, 整个逻辑是通的.
-----
总结一下位置参数和关键字参数,共两点:
1.从外观看,位置参数就是一个变量名,如a,b,c,d等; 关键字参数表面看就是一个等式,如age=18, name="张三"等.
2.函数调用时,位置参数必须传值;关键字参数可传可不传,传值时用的是传给它的这个值,不传时,用的是在函数声明时的那个默认值. //上面讲关键字参数的时候,函数调用时只说了可以直接使用hello()调用,此时,name使用函数定义时的默认值,"张三". 这里再补一个使用自定义值的,即在讲关键字参数的那个hello函数中, 我们还可以使用hello("王五"), hello("赵六")的形式进行调用,此时print(name)输出的值就不再是默认的"张三"了, 而是我们自定义的"王五","赵六".
-----
通过上面的讲解,应该能认出什么叫位置参数,什么叫关键字参数了,其特征(一个是变量名, 一个是等式)和用法(一个是必须传值,一个是可传可不传)应该也能明白了. 那么这里就再举一个同时含有 位置参数和关键字参数的例子:
按照之前讲的,调用person时,age必须要传值,name可传可不传,所以调用形式可以是:
person(18), 也可以是person(18,"李四") //同时把参数名加上进行调用也可以,即person(age=18,"李四"), person(age=18, name="李四"), person(18,name="李四")这都是合法的,当然如果看着乱,记住一种就好.
**.还有一点需要注意函数定义中,位置参数一定要位于关键字参数前,也就是说def person(name="张三",age)这么写是错误的(对于这条约定我是这么理解的, 你想啊假如位置参数位于关键字参数前是可行的,则我们在调用person时,即使name就是默认值"张三",我们也要传值, 因为如果你这么写,person(18),则18会传给person的第一个参数name,如果你写person("张三",18)又麻烦了,因为name的默认值就是"张三', 但我觉得使用person(age=18)还可以理解呀,不管怎么样吧,记住规矩就是这样的.).
-----
下面就该引出题主问题中所谓的"不定长参数"了. 我感觉叫"任意数量的参数"更好理解一些,因为重点在于数量,而不在于长度.//至少如果我没有看到你的实际题目,你说"不定长参数"我会理解为一个参数的值的长度不限, 而非可以有任意多个参数.
为了迎合题主, 下面就称"不定长参数"吧.
python中一般不定长参数有两种类型,位置不定长参数和关键字不定长参数, 其外在特征是:
位置不定长参数由一个星号+变量名组成: *var //var是我随意写的,可以是*a,*b,*any等
关键字不定长参数由两个星号+变量名组成: **key //同理,key也可以是任意名称.
-----
不定长参数的出现其实就是为了增加函数的灵活性, 这个灵活性就体现在"可以表示任意多个参数位置参数和或关键字参数".
-----
最后再说回题主的问题:
def hh(w,**l,pu='d')
这个用法不对, pu='d'要放在**l前面,我说下原因:
先看一下hh这个函数中的参数类型有两种, w是位置参数; **l和pu='d'是关键字参数.
因此w放在最前面没毛病(位置参数要位于关键字参数前面), 而为什么pu='d'要放在**l前面呢,因为**l表示所有的关键字参数都要传给l,所以如果pu='d'写在**l后面,则pu='d'就不起作用了,因此不能这样写.
=====
希望可以帮到题主, 欢迎追问.
1.常用内置函数:(不用import就可以直接使用)
help(obj) 在线帮助, obj可是任何类型
callable(obj) 查看一个obj是不是可以像函数一样调用
repr(obj) 得到obj的表示字符串,可以利用这个字符串eval重建该对象的一个拷贝
eval_r(str) 表示合法的python表达式,返回这个表达式
dir(obj) 查看obj的name space中可见的name
hasattr(obj,name) 查看一个obj的name space中是否有name
getattr(obj,name) 得到一个obj的name space中的一个name
setattr(obj,name,value) 为一个obj的name space中的一个name指向vale这个object
delattr(obj,name) 从obj的name space中删除一个name
vars(obj) 返回一个object的name space。用dictionary表示
locals() 返回一个局部name space,用dictionary表示
globals() 返回一个全局name space,用dictionary表示
type(obj) 查看一个obj的类型
isinstance(obj,cls) 查看obj是不是cls的instance
issubclass(subcls,supcls) 查看subcls是不是supcls的子类
类型转换函数
chr(i) 把一个ASCII数值,变成字符
ord(i) 把一个字符或者unicode字符,变成ASCII数值
oct(x) 把整数x变成八进制表示的字符串
hex(x) 把整数x变成十六进制表示的字符串
str(obj) 得到obj的字符串描述
list(seq) 把一个sequence转换成一个list
tuple(seq) 把一个sequence转换成一个tuple
dict(),dict(list) 转换成一个dictionary
int(x) 转换成一个integer
long(x) 转换成一个long interger
float(x) 转换成一个浮点数
complex(x) 转换成复数
max(...) 求最大值
min(...) 求最小值
用于执行程序的内置函数
complie 如果一段代码经常要使用,那么先编译,再运行会更快。
2.和操作系统相关的调用
系统相关的信息模块 import sys
sys.argv是一个list,包含所有的命令行参数.
sys.stdout sys.stdin sys.stderr 分别表示标准输入输出,错误输出的文件对象.
sys.stdin.readline() 从标准输入读一行 sys.stdout.write("a") 屏幕输出a
sys.exit(exit_code) 退出程序
sys.modules 是一个dictionary,表示系统中所有可用的module
sys.platform 得到运行的操作系统环境
sys.path 是一个list,指明所有查找module,package的路径.
操作系统相关的调用和操作 import os
os.environ 一个dictionary 包含环境变量的映射关系 os.environ["HOME"] 可以得到环境变量HOME的值
os.chdir(dir) 改变当前目录 os.chdir('d:\\outlook') 注意windows下用到转义
os.getcwd() 得到当前目录
os.getegid() 得到有效组id os.getgid() 得到组id
os.getuid() 得到用户id os.geteuid() 得到有效用户id
os.setegid os.setegid() os.seteuid() os.setuid()
os.getgruops() 得到用户组名称列表
os.getlogin() 得到用户登录名称
os.getenv 得到环境变量
os.putenv 设置环境变量
os.umask 设置umask
os.system(cmd) 利用系统调用,运行cmd命令
操作举例:
os.mkdir('/tmp/xx') os.system("echo 'hello' /tmp/xx/a.txt") os.listdir('/tmp/xx')
os.rename('/tmp/xx/a.txt','/tmp/xx/b.txt') os.remove('/tmp/xx/b.txt') os.rmdir('/tmp/xx')
用python编写一个简单的shell
#!/usr/bin/python
import os, sys
cmd = sys.stdin.readline()
while cmd:
os.system(cmd)
cmd = sys.stdin.readline()
用os.path编写平台无关的程序
os.path.abspath("1.txt") == os.path.join(os.getcwd(), "1.txt")
os.path.split(os.getcwd()) 用于分开一个目录名称中的目录部分和文件名称部分。
os.path.join(os.getcwd(), os.pardir, 'a', 'a.doc') 全成路径名称.
os.pardir 表示当前平台下上一级目录的字符 ..
os.path.getctime("/root/1.txt") 返回1.txt的ctime(创建时间)时间戳
os.path.exists(os.getcwd()) 判断文件是否存在
os.path.expanduser('~/dir') 把~扩展成用户根目录
os.path.expandvars('$PATH') 扩展环境变量PATH
os.path.isfile(os.getcwd()) 判断是否是文件名,1是0否
os.path.isdir('c:\Python26\temp') 判断是否是目录,1是0否
os.path.islink('/home/huaying/111.sql') 是否是符号连接 windows下不可用
os.path.ismout(os.getcwd()) 是否是文件系统安装点 windows下不可用
os.path.samefile(os.getcwd(), '/home/huaying') 看看两个文件名是不是指的是同一个文件
os.path.walk('/home/huaying', test_fun, "a.c")
遍历/home/huaying下所有子目录包括本目录,对于每个目录都会调用函数test_fun.
例:在某个目录中,和他所有的子目录中查找名称是a.c的文件或目录。
def test_fun(filename, dirname, names): //filename即是walk中的a.c dirname是访问的目录名称
if filename in names: //names是一个list,包含dirname目录下的所有内容
print os.path.join(dirname, filename)
os.path.walk('/home/huaying', test_fun, "a.c")
文件操作
打开文件
f = open("filename", "r") r只读 w写 rw读写 rb读二进制 wb写二进制 w+写追加
读写文件
f.write("a") f.write(str) 写一字符串 f.writeline() f.readlines() 与下read类同
f.read() 全读出来 f.read(size) 表示从文件中读取size个字符
f.readline() 读一行,到文件结尾,返回空串. f.readlines() 读取全部,返回一个list. list每个元素表示一行,包含"\n"\
f.tell() 返回当前文件读取位置
f.seek(off, where) 定位文件读写位置. off表示偏移量,正数向文件尾移动,负数表示向开头移动。
where为0表示从开始算起,1表示从当前位置算,2表示从结尾算.
f.flush() 刷新缓存
关闭文件
f.close()
regular expression 正则表达式 import re
简单的regexp
p = re.compile("abc") if p.match("abc") : print "match"
上例中首先生成一个pattern(模式),如果和某个字符串匹配,就返回一个match object
除某些特殊字符metacharacter元字符,大多数字符都和自身匹配。
这些特殊字符是 。^ $ * + ? { [ ] \ | ( )
字符集合(用[]表示)
列出字符,如[abc]表示匹配a或b或c,大多数metacharacter在[]中只表示和本身匹配。例:
a = ".^$*+?{\\|()" 大多数metachar在[]中都和本身匹配,但"^[]\"不同
p = re.compile("["+a+"]")
for i in a:
if p.match(i):
print "[%s] is match" %i
else:
print "[%s] is not match" %i
在[]中包含[]本身,表示"["或者"]"匹配.用
和
表示.
^出现在[]的开头,表示取反.[^abc]表示除了a,b,c之外的所有字符。^没有出现在开头,即于身身匹配。
-可表示范围.[a-zA-Z]匹配任何一个英文字母。[0-9]匹配任何数字。
\在[]中的妙用。
\d [0-9]
\D [^0-9]
\s [ \t\n\r\f\v]
\S [^ \t\n\r\f\v]
\w [a-zA-Z0-9_]
\W [^a-zA-Z0-9_]
\t 表示和tab匹配, 其他的都和字符串的表示法一致
\x20 表示和十六进制ascii 0x20匹配
有了\,可以在[]中表示任何字符。注:单独的一个"."如果没有出现[]中,表示出了换行\n以外的匹配任何字符,类似[^\n].
regexp的重复
{m,n}表示出现m个以上(含m个),n个以下(含n个). 如ab{1,3}c和abc,abbc,abbbc匹配,不会与ac,abbbc匹配。
m是下界,n是上界。m省略表下界是0,n省略,表上界无限大。
*表示{,} +表示{1,} ?表示{0,1}
最大匹配和最小匹配 python都是最大匹配,如果要最小匹配,在*,+,?,{m,n}后面加一个?.
match object的end可以得到匹配的最后一个字符的位置。
re.compile("a*").match('aaaa').end() 4 最大匹配
re.compile("a*?").match('aaaa').end() 0 最小匹配
使用原始字符串
字符串表示方法中用\\表示字符\.大量使用影响可读性。
解决方法:在字符串前面加一个r表示raw格式。
a = r"\a" print a 结果是\a
a = r"\"a" print a 结果是\"a
使用re模块
先用re.compile得到一个RegexObject 表示一个regexp
后用pattern的match,search的方法,得到MatchObject
再用match object得到匹配的位置,匹配的字符串等信息
RegxObject常用函数:
re.compile("a").match("abab") 如果abab的开头和re.compile("a")匹配,得到MatchObject
_sre.SRE_Match object at 0x81d43c8
print re.compile("a").match("bbab")
None 注:从str的开头开始匹配
re.compile("a").search("abab") 在abab中搜索第一个和re_obj匹配的部分
_sre.SRE_Match object at 0x81d43c8
print re.compile("a").search("bbab")
_sre.SRE_Match object at 0x8184e18 和match()不同,不必从开头匹配
re_obj.findall(str) 返回str中搜索所有和re_obj匹配的部分.
返回一个tuple,其中元素是匹配的字符串.
MatchObject的常用函数
m.start() 返回起始位置,m.end()返回结束位置(不包含该位置的字符).
m.span() 返回一个tuple表示(m.start(), m.end())
m.pos(), m.endpos(), m.re(), m.string()
m.re().search(m.string(), m.pos(), m.endpos()) 会得到m本身
m.finditer()可以返回一个iterator,用来遍历所有找到的MatchObject.
for m in re.compile("[ab]").finditer("tatbxaxb"):
print m.span()
高级regexp
| 表示联合多个regexp. A B两个regexp,A|B表示和A匹配或者跟B匹配.
^ 表示只匹配一行的开始行首,^只有在开头才有此特殊意义。
$ 表示只匹配一行的结尾
\A 表示只匹配第一行字符串的开头 ^匹配每一行的行首
\Z 表示只匹配行一行字符串的结尾 $匹配第一行的行尾
\b 只匹配词的边界 例:\binfo\b 只会匹配"info" 不会匹配information
\B 表示匹配非单词边界
示例如下:
print re.compile(r"\binfo\b").match("info ") #使用raw格式 \b表示单词边界
_sre.SRE_Match object at 0x817aa98
print re.compile("\binfo\b").match("info ") #没有使用raw \b表示退格符号
None
print re.compile("\binfo\b").match("\binfo\b ")
_sre.SRE_Match object at 0x8174948
分组(Group) 示例:re.compile("(a(b)c)d").match("abcd").groups() ('abc', 'b')
#!/usr/local/bin/python
import re
x = """
name: Charles
Address: BUPT
name: Ann
Address: BUPT
"""
#p = re.compile(r"^name:(.*)\n^Address:(.*)\n", re.M)
p = re.compile(r"^name:(?P.*)\n^Address:(?P.*)\n", re.M)
for m in p.finditer(x):
print m.span()
print "here is your friends list"
print "%s, %s"%m.groups()
Compile Flag
用re.compile得到RegxObject时,可以有一些flag用来调整RegxObject的详细特征.
DOTALL, S 让.匹配任意字符,包括换行符\n
IGNORECASE, I 忽略大小写
LOCALES, L 让\w \W \b \B和当前的locale一致
MULTILINE, M 多行模式,只影响^和$(参见上例)
VERBOSE, X verbose模式
在进行write过后,文件的指针,也就是正常操作文件的光标已经到了最后一个字符“哈”的后面了。
可以用f.seek(0)将文件指针设置回开头,此时使用f.read()就有输出结果了。
对于A1: Open 函数中 'w' 代表以写入模式打开文件;
对于A2: target 代表已经打开的文件实例。
target.truncate([size]) #把文件裁成规定的大小,默认的是裁到当前文件操作标记的位置。如果size比文件的大小还要大,依据系统的不同可能是不改变文件,也可能是用0把文件补到相应的大小,也可能是以一些随机的内容加上去。
与大多数编程语言相同,python正则表达式里使用"\"作为转义字符,Python里的原生字符串很好地解决了这个问题,这个例子中的正则表达式可以使用r"\\"表示。
python中调用写文件函数的方法:
使用“open(‘文件路径’, ‘w’)”语句就可以打开文件了,然后用“write(内容)”函数就可以将文件写入进去了
示例代码如下:
执行结果如下:
更多Python知识,请关注:Python自学网!!