python3新特点
Posted Xiao|Deng
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了python3新特点相关的知识,希望对你有一定的参考价值。
#xiaodeng #python 3 #1、编码方式和性能 ‘‘‘ 1、py3运行效率更快 2、默认源文件编码ASCII变为UTF-8,以前文件前加入的coding=utf-8不再需要 3、针对unicode的处理有了明显的改善,效率明显提升 ‘‘‘ #2、数据类型和基本运算 ‘‘‘ 1、int和long进行了统一,统一为int 2、True、False、None都是关键词 3、必须以b‘...‘表示二进制数据,可以使用u‘..‘表示字符串,不加u也表示字符串 4、移除<>不等号,使用“!=”表示不等号关系 1)2!=3 2)2<>3 #出现语法错误 5、调整除法符号‘/’的用法,只返回浮点数,要返回整数要使用“//” 6、py3运算对数据的类型要求更加的严格 ‘‘‘ def foo(test=None): if test is None: print (test) foo() print (5/2) #浮点数 print (5//2) #整数 print (1/3) #4、print和exec用法 ‘‘‘ 1、print是一个函数,不再是一个语句,其中不需要用空格,后面打印的内容需要有括号括起来 2、exec函数用法发生变化 ‘‘‘ def foo(): _local=locals() exec(‘a=4‘,globals(),_local) a=_local[‘a‘] print(a) foo() #5、input、bin、oct和for循环 ‘‘‘ 1、raw_input统一为input 在py2中用法为: 1)a=raw_input(‘请输入:‘) print a 2)a=input(‘请输入:‘) #接收一个有效的表达式,如:2+3,而不能单独接收3 print a 2、for循环的变量不再泄露在全局变量中,此bug已修复 1)Python 2.7.10 (default, May 23 2015, 09:40:32) [MSC v.1500 32 bit (Intel)] on win32 Type "copyright", "credits" or "license()" for more information. >>> i=8 >>> print [i for i in range(5)] [0, 1, 2, 3, 4] >>> print i 4 #按照道理来讲for循环中的i与最外面的i=8的i是不同的,但是这里。。。。。 >>> 2) i=6 print([i for i in range(5)])#结果为[0, 1, 2, 3, 4] print(i)#结果i=6 ‘‘‘ #6、a=input(‘请输入:‘)#这里不再需要一个有效的表达式,他的用法和raw_input相同 #print(a) #7、range和dict的变化 ‘‘‘ 1、在python2中,range火xrange会创建一个列表。常出现在for循环、字典、列表中,但是py3中xrange改名为range,在python3中使用 使用xrange会触发错误。同时range返回的是可迭代对象而不再是列表形式,要想使range的结果得到一个list数据必须要使用list(range(5)) 2、字典内的dict.iterkeys(),dict.itervalues(),dict.iteritems()被keys() and values() and items()所替代 他们的返回结果类似于集的可迭代对象,而不是键值对的列表。从而在不进行键和值条目复制的情况下就能对其执行set操作 ‘‘‘ a=range(6) print(a)#result:range(0,6)对象,不是列表 print(list(a))#result:[0, 1, 2, 3, 4, 5] for i in range(6): print(i) #print(xrange(5)) #报错:提示为name"xrange" is‘not defined #dict案例 d={‘name‘:"iaodeng",‘sex‘:28} print(d.items()) print(type(d.items())) #<class ‘dict_items‘> #返回结果 dict_items([(‘name‘, ‘iaodeng‘), (‘sex‘, 28)]) #这里不再是列表形式 ‘‘‘ Python 2.7.10 (default, May 23 2015, 09:40:32) [MSC v.1500 32 bit (Intel)] on win32 Type "copyright", "credits" or "license()" for more information. >>> d={‘name‘:"iaodeng",‘sex‘:28} >>> print d {‘name‘: ‘iaodeng‘, ‘sex‘: 28} >>> print d.items() [(‘name‘, ‘iaodeng‘), (‘sex‘, 28)] >>> print d.iteritems() #返回一个可迭代对象 <dictionary-itemiterator object at 0x0275E930> >>> for i in d.iteritems():print i (‘name‘, ‘iaodeng‘) (‘sex‘, 28) >>> ‘‘‘ print(‘xiaodeng: d.keys():‘,d.keys()) #xiaodeng: d.keys(): dict_keys([‘name‘, ‘sex‘]) print(type(d.keys()))#<class ‘dict_items‘> #values()同理 print("既然是可迭代对象,那么还可以进行下面操作") for i in d.items(): print(i) for key in d.keys(): print(key) print("values用法同理") print(‘用list将可迭代对象转化为list数据‘) print(list(d.values())) #7、python3具有单一的str类型,其类型相当于python2的unicode,python3所有的字符串都是unicode #新增bytes类型 a=b"china" print(type(a)) #<class ‘bytes‘> #str和tytes对象都可以使用encode和decode来进行转化 s=a.decode() print(s) #china 字符串类型 s=s.encode() print(s) #b"china", tytes字节类型 #8、输入和输出 a=open(‘test.txt‘,‘w‘) a.write("write in something") a.close() b=open("test.txt","r") print(b.read()) #note:注意加括号 """ 1、如果要对文本执行任何I/O操作,python3会强制用户使用文本模式,打开文件,如果不想使用默认编码utf-8 通常需要指明所需的编码 2、如果对二进制数据进行I/O操作,必须使用二进制模式打开文件或进行读写操作 eg: f=open("test1.txt","wb+") #二进制追加模式 f.write(b"w love fengmei") #必须加b,以bytes对象的形式进行写入 f.close() file=open(filename,mode) mode: r:只读模式 w:只写,如果文件已存在则会进行覆盖操作,所以格外小心,如果文件不存在则创建新的文件 a:打开文件用于追加,只写如果文件不存在则创建 b:二进制,不能单独使用 经过演变会有很多形式 """ #9、迭代器 """ 1、range在python3中返回颗迭代对象二不是列表,最大限度节约内存 2、zip(),map(),filter(),key(),value()返回的均是可迭代对象 """ #10、异常错误处理 """ 1、必须使用关键词as,try 和except NameError as e语句 2、案例: python 2 try: something except NameError,err: print err python3 try: something except NameError as err: print(err) 3、raise触发语法用法的变化,python3只接受带括号的 1)raise IOError,"file error" #出现语法错误 2)raise IOError("file error") """ #11、面向对象 """ 1、需要单独深入学习 """ #12、模块的变动
以上是关于python3新特点的主要内容,如果未能解决你的问题,请参考以下文章