最近一直在用python写程序,对于python的打印一直很恼火,老是不按照预期输出。在python2中打印是一种输出语句,和如果语句,虽然语句一样的东西,在python3中为了填补python2的各种坑,将打印变为函数,因此导致python3中打印的一些使用和python2很不一样,同时,python3大改python2中的字符串格式化,主推格式()函数格式,用法很是灵活,让老用户一时摸不着头脑。今天特来总结一样和打印格式,也希望能帮助大家彻底理解它们。
<强> 1.印刷使用说明强>
在python2中打印是这样的:
在python3中打印是以函数形式出现的:
可以很明显的看出python3已经不支持打印非函数格式了,在python3中使用印刷,必须加()。
我们在python3中帮助(印刷):,(注意,在python2中是不能帮助(印刷)的,因为其不是一个函数)
可以清楚看到打印函数的几个参数,文件是文件描述符,冲洗控制是否冲刷缓冲区,最终为结束字符,默认为换行,9月是输出的几个变量间的字符,默认为空格。弄清楚这些,以后操作起来就顺溜了。
试试看:
上面是python3,可以看到改变结束为空字符就能避免换行,下面是python2,奇怪的是说好的不换行还是换了…
谁能告诉我怎么打出一个不换行啊…
总结一下,感觉python3还是非常优秀的,比python2上了一个档次,更加方便开发者了,与python2中异常丑陋的打印在祝辞文件相比,打印的函数化确实更上一层楼.print也就这样啦,下面来看看字符串格式化把。
<强> 2。字符串格式>强化
在python2中一直使用形如:“% s ....,% d % (str,…intNum)格式化字符串的。这是python从C系列借鉴过来的语法,但是这种语法对于C这种静态语言足够快足够好,但是对于拥有很多先进数据结构的python来说就有点心有余来力不足了。为什么这么说呢? python的几把利刃:元组,列表,字典,集合等不适合用这种结构表示,这些利刃大多元素用下标表示,在这种结构中写出来很丑陋,不信你试试。
不管怎么样,这种表示方法还是必须掌握的,大多数情况下表示起来还是特别快速的。
字符串格式化代码:
看着这么的多格式,其实常用的也就那么几个,总结一些只需要记住:% d % s, % f就好了,其实等需要用的时候查找就可以了,毕竟我们大脑的资源是很宝贵的,可不能全用来记这些死板的东西
再来看看《Python基础编程》中对格式化输出的总结:
(1)。%字符:标记转换说明符的开始
(2)。转换标志:表示左对齐;+表示在转换值之前要加上正负号;”“(空白字符)表示正数之前保留空格;0表示转换值若位数不够则用0填充
(3)。最小字段宽度:转换后的字符串至少应该具有该值指定的宽度。如果是*,则宽度会从值元组中读出。
(4)。点(.)后跟精度值:如果转换的是实数,精度值就表示出现在小数点后的位数。如果转换的是字符串,那么该数字就表示最大字段宽度。如果是*,那么精度将从元组中读出。
下面来看看python3主打的格式化函数格式()。
<强> 1。通过位置标号强>
{0}表示第一个元素,{1}表示第二个元素,{2}表示第三个元素,以此类推…
注意在这里的顺序是按照格式中的参数顺序而言的,在字符串中{0},{1}位置随便。
<强> 2。通过关键字参数强>
<强> 3。通过属性和下标强>
<强>