1.print

1.1 Print是一个函数

在Python3中print是个函数,这意味着在使用的时候必须带上小括号,并且它是带有参数的。

>>> print 'hello world'
  SyntaxError: Missing parentheses in call to 'print'
   >>>

Python版本更新后,3.X的版本中去掉了很多的函数,在3.X版本的python中,print需要加上括号

如:

>>> print ('hello world')
    hello world
    >>>

另:将数据输出为一组时,python2.x直接在需要输出数据后面加上“,”即可,但python3.x中使用此方法无效,应该使用如下代码:

>>>   print (item, end=" ")

格式化输出

类似于C中的 printf,  %字符:标记转换说明符的开始

在Python 3.2.3中  input和raw_input 整合了,没有了raw_input

不换号:

# pythong3中,这个是python3中的写法,注意end='',是一对单引号
for x in range(0,10):
print(x,end= '')

#python2中,是用一个逗号

for x in range(0,10):
print x,

0 1 2 3 4 5 6 7 8 9

old: print (x, y)   # 打印出元组(x, y)
new: print((x, y)) # 同上,在python3中print(x, y)的结果是跟这不同的

在Python3中还可以定义分隔符,使用参数sep来指定.

print("There are <", 2+5, ">possibilities", sep="")

上面代码的结果如下:

There are <7> possibilities

注意:

  • print()函数不支持Python2.X中print中的“软空格”。在Python2.X中,print "A\n", "B"的结果是"A\nB\n";而在Python3中print("A\n", "B")的结果是"A\n B\n"。

  • 在刚开始使用Python3的时候,你会发现你经常在交互模式下你还是经常使用老式的语法print x,是时候锻炼你的手指用print(x)来取代它啦。

  • 如果你的项目比较大,而又想升级到Python3的时候,不用担心,2to3这个工具会将所有的print语句转换为print()函数。

2.input

>>> myName=raw_input('Ener your name:')
   Traceback (most recent call last):
   File "<pyshell#129>", line 1, in <module>
   myName=raw_input('Ener your name:')
   NameError: name 'raw_input' is not defined
   >>>

同1,因版本问题。可直接用input代替

如:

>>> myName=input('Ener your name:')
    Ener your name:cookie
    >>>

3.decimal

>>> print (decimal.Decimal('1.1'))
    Traceback (most recent call last):
    File "C:/Users/cookie/Desktop/bb.py", line 2, in <module>
    print (decimal.Decimal('1.1'))
    NameError: name 'decimal' is not defined
    >>>

错误提示‘decimal’ 未定义,导入decimal包即可

如:

>>> import decimal
     >>> print (decimal.Decimal('1.1'))
         1.1
     >>>

 

4.使用Views和Iterators代替Lists

  • dict的方法dict.keys(),dict.items(),dict.values()不会再返回列表,而是返回一个易读的“views”。这样一来,像这样的语法将不再有用了:k = d.keys();k.sort(),你可以使用k = sorted(d)来代替。sorted(d)在Python2.5及以后的版本中也有用,但是Python3效率更高了。
d = {'a': 1}
d.keys() # dict_keys(['a'])
d.items() # dict_items([('a', 1)])
d.values() # dict_values([1])
k = d.keys(); k.sort() # AttributeError: 'dict_keys' object has no attribute 'sort'
  • 同样,dict.iterkeys(),dict.iteritems(),dict.itervalues()方法也不再支持。
  • map()和filter()将返回iterators。如果你真的想要得到列表,list(map(...))是一个快速的方法,但是更好的方法是使用列表推导(尤其是原代码使用了lambda表达式的时候),或者重写原来的代码,改为不需要使用列表。特别是map()会给函数带来副作用,正确的方法是改为使用for循环,因为创建一个列表是非常浪费的事情。

  • Python3中的range()函数跟Python2.X的xrange()函数的作用是一样的,这样可以使用任意的数字,Python3中去除了xrange()函数。

  • zip()在Python3中返回的是一个迭代器。

5 比较符

Python3简化了比较符。

  • 在使用比较符(<,<=,>=,>)时,当相比较的操作数的排序是没有意义的时候将会抛出TypeError异常,因此像1 < '',0 > None,len <= len这样的语句不再合法了。None < None也会抛出TypeError异常,而不是返回False。你应该明白了,胡乱的比较是没有意义的,相比较的元素必须是能够比较的才行。需要注意的是,==和!=不包括在内,因为不通类型的,无法比较元素总是不等于另一个的。

  • builtin.sorted和list.sort()不再有提供比较函数的cmp参数,只有参数key和reverse。

  • cmp()函数应该当做被去除了,__cmp__()特殊方法也不再支持。在需要的时候使用__lt__,__eg__和__hash__。

6 整型数

  • 从本质上来说,long重命名了int,因为在内置只有一个名为int的整型,但它基本跟之前的long一样。

  • 像1/2这样的语句将返回float,即0.5。使用1//2来获取整型,这也是之前版本所谓的“地板除”。

  • 移除了sys.maxint,因为整型数已经没了限制。sys.maxsize可以用来当做一个比任何列表和字符串下标都要大的整型数。

  • repr()中比较大的整型数将不再带有L后缀。

  • 八进制数的字面量使用0o720代替了0720。

7 Text Vs. Data 代替 Unicode Vs. 8-bit

Python3中改变了二进制数据和Unicode字符串。

  • Python3使用文本和(二进制)数据的理念代替之前的Unicode字符串和8-bit字符串,所有的文本默认是Unicode编码。使用str类型保存文本,使用bytes类型保存数据。当你混淆文本和数据的时候Python3会抛出TypeError的错误。

  • 不能再使用u"..."字面量表示unicode文本,而必须使用b"..."字面量表示二进制数据。

  • 因为str和bytes不能弄混,所以你必须显式地将他们进行转换。使用str.encode()将str转换为bytes,使用bytes.decode()将bytes转换为str,也可以使用bytes(s, encoding=...)和str(b, encoding=...)。

  • str和bytes都是不可变的类型,有一个分离的可变类型的bytearray可以保存缓存的二进制数据,所有能够接受bytes的API都能够使用bytearray。这些可变的API是基于collections.MutableSequence的。

  • 移除了抽象类型basestring,使用str代替。

  • 文件默认使用文本类型打开,这也是open()函数默认的。如果要打开二进制文件必须使用b参数,否则会出现错误,而不会默默地提供错误的数据。

  • 文件名都使用unicode字符串传入和输出,变量名也是,所以可以使用中文作为变量名,例如 中国="China"; print(中国) 。关于 python2 的编码问题请参考:详解python中文编码与处理 http://my.oschina.net/leejun2005/blog/74430

  • 一些关于系统的API,如os.environ和sys.argv,当系统允许bytes并且不能正常转换为unicode的话,也会出现问题。所以,将系统的LANG设置好是最好的做法。

  • repr()函数不再转义非ASCII字符。

  • 代码默认为UTF-8编码。

  • 移除了StringIO和cStringIO。加入了io模块,并分别使用io.StringIO和io.BytesIO分别用于text和data。

2、语法改变

2.1 新增语法

  • 函数变量和返回值annotations

  • Keyword-only变量。

  • nonlocal声明。使用nonlocal x可以直接引用一个外部作用域的变量,但不是全局变量。

  • 扩展了迭代的解包。
(a, *rest, b) = range(5)
a # 0
rest # [1,2,3]
b # 4
  • 字典推导。{k: v for k, v in stuff }。
t = ((1,1), (2,2))
d = {k: v for k, v in t}
d # {1: 1, 2: 2}
  • 集合推导。{x for x in stuff},与set(stuff)效果一样,但是更加灵活。

  • 八进制字面量0o720。

  • 二进制字面量0b1010,相当于新的内置函数bin()。

  • 字节字面量b或者B,相当于新的内置函数bytes()。

2.2 改变的语法

  • 将except exc, var改为except exc as var。

  • 新的元类语法。
# old
class C:
__metaclass__ = M
.... # new
class C(metaclass=M):
....
  • 列表推导不再支持[... for var in item1, item2, ...],必须写成[... for var in (item1, item2,...)]。
  • 省略号...作为连续表达式可以用于任何地方,之前只能用于分片中。但是必须连续写,之前带空格的. . .不再支持。

2.3 移除的语法

  • 移除了元组的解包。不能再写def foo(a, (b, c)): ....,需要写成def foo(a, b_c):b, c = b_c。

  • 移除<>,使用!=代替。

  • exec()不能再作为关键词,只能作为一个函数。并且exec()不再支持流变量,如exec(f)需写成exec(f.read())。

  • 整型不支持l/L后缀。

  • 字符串不支持'u/U'前缀。

  • from module import *只能用在模块级,在函数中不可使用。

  • 所有不以.开始的import语句均作为绝对路径的import对待。

  • 移除了经典类。

3、推荐阅读:

使用 2to3 将代码移植到 Python 3

http://woodpecker.org.cn/diveintopython3/porting-code-to-python-3-with-2to3.html

Moving from Python 2 to Python 3

http://ptgmedia.pearsoncmg.com/imprint_downloads/informit/promotions/python/python2python3.pdf

python3.X中简单错误处理,和Python2区别的更多相关文章

  1. Python中的全局变量与局部变量的区别

    全局变量与局部变量两者的本质区别就是在于作用域 用通俗的话来理解的话, 全局变量是在整个py文件中声明,全局范围内都可以访问 局部变量是在某个函数中声明的,只能在该函数中调用它,如果试图在超出范围的地 ...

  2. Linux系统中python默认版本为python2.7,修改为python3 项目上传码云

    # 查询系统本系统中安装的python版本 ls -l /usr/bin/python* 1.在虚拟机上新建虚拟环境 # 系统中python默认版本为python2.,可以将其修改为python3 # ...

  3. python3中的 zip()函数 和python2中的 zip()函数 的区别

    python3中的 zip()函数 和python2中的 zip()函数 的区别: 描述: zip() 函数用于将可迭代对象作为参数,将对象中对应的元素打包成一个个元组,然后返回由这些元组组成的对象. ...

  4. Python2.X和Python3.X中的urllib区别

    Urllib是Python提供的一个用于操作URL的模块,在Python2.X中,有Urllib库,也有Urllib2库,在Python3.X中Urllib2合并到了Urllib中,我们爬取网页的时候 ...

  5. 使用python2与python3创建一个简单的http服务(基于SimpleHTTPServer)

    python2与python3基于SimpleHTTPServer创建一个http服务的方法是不同的: 一.在linux服务器上面检查一下自己的python版本:如: [root@zabbix ~]# ...

  6. Python 中常见错误总结

    IndentationError: unexpected indent Python 中强制缩进,, IndentationError: unexpected indent 缩进错误 这类错误非常常见 ...

  7. 【译】深入理解python3.4中Asyncio库与Node.js的异步IO机制

    转载自http://xidui.github.io/2015/10/29/%E6%B7%B1%E5%85%A5%E7%90%86%E8%A7%A3python3-4-Asyncio%E5%BA%93% ...

  8. Python3+Dlib实现简单人脸识别案例

    Python3+Dlib实现简单人脸识别案例 写在前边 很早很早之前,当我还是一个傻了吧唧的专科生的时候,我就听说过人脸识别,听说过算法,听说过人工智能,并且也出生牛犊不怕虎般的学习过TensorFl ...

  9. python3.4中自定义wsgi函数,make_server函数报错问题

    别的不多说,先上代码 #coding:utf-8 from wsgiref.simple_server import make_server def RunServer(environ, start_ ...

随机推荐

  1. PAT甲级1026. Table Tennis

    PAT甲级1026. Table Tennis 题意: 乒乓球俱乐部有N张桌子供公众使用.表的编号从1到N.对于任何一对玩家,如果有一些表在到达时打开,它们将被分配给具有最小数字的可用表.如果所有的表 ...

  2. php 安装 Redis 扩展

    开发环境安装包为:wamp3.1.0,安装成功后 wamp/bin 目录下有php以下几个版本: 这里以php7.1.9为例进行redis扩展安装,其他php版本也是一样的. 进行安装 step 1: ...

  3. 函数调用过程中,函数参数的入栈顺序,why?

    C语言函数参数入栈顺序为从右至左.具体原因为:C方式参数入栈顺序(从右至左)的好处就是可以动态变化参数个数.通过栈堆分析可知,自左向右的入栈方式,最前面的参数被压在栈底.除非知道参数个数,否则是无法通 ...

  4. 典型案例收集-使用OpenVPN连通多个机房内网(转)(静态路由)

    说明: 1.这篇文章主要是使用静态路由表实现的多个机房通过VPN连接后的子网机房互通. 2.OpenVPN使用的是桥接模式(server-bridge和dev tap),这个是关键点,只有这样设置才可 ...

  5. HDU 4611 Balls Rearrangement(2013多校2 1001题)

    Balls Rearrangement Time Limit: 9000/3000 MS (Java/Others)    Memory Limit: 65535/32768 K (Java/Othe ...

  6. SDRAM interface slashes pin count

    Many designs need deep buffering but don't require ultrahigh-memory bandwidth. Examples include imag ...

  7. mOByDiC E90C2600 EOBD/OBDII to RS232 gateway

    http://www.ozenelektronik.com/downs/pdf/oe90c2600.pdf Features • Compatible with EOBD/OBDII standard ...

  8. Android SDK Manager 代理服务器设置

    http://blog.csdn.net/star_splendid/article/details/6939063 自己机子更新的话,速度1KB/s 实在是等不及了~找方法吧 http://www. ...

  9. 掌握11项技能,你就是优秀的前端开发project师

    导读: 你或许会认为前端开发是一个非常easy的工作,对呀,你就是刚刚从网页设计转型过来的.但当你深入当中时,一定会发现好像前端开发不是那么简单,光站点性能优化.响应式.框架就让你焦头烂额, 确实,做 ...

  10. mysql -- 用索引应避免空值

    由于数据库的复杂性,以讹传讹的空间非常大,快赶上中医养生了.避免使用 NULL 的理由,在高性能MySQL里有提到一段.建议大家多读些书,少看网上的奇技淫巧.特意把书翻出来摘录了下以供参考: 要尽量避 ...