Rumah >pembangunan bahagian belakang >Tutorial Python >Python内置format函数详细介绍

Python内置format函数详细介绍

高洛峰
高洛峰asal
2017-03-21 11:15:532129semak imbas

英文文档:

format(value[, format_spec])

Convert a value to a “formatted” representation, as controlled by format_spec. The interpretation of format_spec will depend on the type of the value argument, however there is a standard formatting syntax that is used by most built-in types: Format Specification Mini-Language.

The default format_spec is an empty string which usually gives the same effect as calling str(value).

A call to <span class="pre">format(value, <span class="pre">format_spec)</span></span> is translated to <span class="pre">type(value).__format__(value, <span class="pre">format_spec)</span></span> which bypasses the instance dictionary when searching for the value’s __format__() method. A TypeError exception is raised if the method search reaches object and the format_spec is non-empty, or if either the format_spec or the return value are not strings.

 

说明:

  1. 函数功能将一个数值进行格式化显示。

  2. 如果参数format_spec未提供,则和调用str(value)效果相同,转换成字符串格式化。

>>> format(3.1415936)
&#39;3.1415936&#39;
>>> str(3.1415926)
&#39;3.1415926&#39;

  3. 对于不同的类型,参数format_spec可提供的值都不一样

#字符串可以提供的参数 &#39;s&#39; None
>>> format(&#39;some string&#39;,&#39;s&#39;)
&#39;some string&#39;
>>> format(&#39;some string&#39;)
&#39;some string&#39;

#整形数值可以提供的参数有 &#39;b&#39; &#39;c&#39; &#39;d&#39; &#39;o&#39; &#39;x&#39; &#39;X&#39; &#39;n&#39; None
>>> format(3,&#39;b&#39;) #转换成二进制
&#39;11&#39;
>>> format(97,&#39;c&#39;) #转换unicode成字符
&#39;a&#39;
>>> format(11,&#39;d&#39;) #转换成10进制
&#39;11&#39;
>>> format(11,&#39;o&#39;) #转换成8进制
&#39;13&#39;
>>> format(11,&#39;x&#39;) #转换成16进制 小写字母表示
&#39;b&#39;
>>> format(11,&#39;X&#39;) #转换成16进制 大写字母表示
&#39;B&#39;
>>> format(11,&#39;n&#39;) #和d一样
&#39;11&#39;
>>> format(11) #默认和d一样
&#39;11&#39;

#浮点数可以提供的参数有 &#39;e&#39; &#39;E&#39; &#39;f&#39; &#39;F&#39; &#39;g&#39; &#39;G&#39; &#39;n&#39; &#39;%&#39; None
>>> format(314159267,&#39;e&#39;) #科学计数法,默认保留6位小数
&#39;3.141593e+08&#39;
>>> format(314159267,&#39;0.2e&#39;) #科学计数法,指定保留2位小数
&#39;3.14e+08&#39;
>>> format(314159267,&#39;0.2E&#39;) #科学计数法,指定保留2位小数,采用大写E表示
&#39;3.14E+08&#39;
>>> format(314159267,&#39;f&#39;) #小数点计数法,默认保留6位小数
&#39;314159267.000000&#39;
>>> format(3.14159267000,&#39;f&#39;) #小数点计数法,默认保留6位小数
&#39;3.141593&#39;
>>> format(3.14159267000,&#39;0.8f&#39;) #小数点计数法,指定保留8位小数
&#39;3.14159267&#39;
>>> format(3.14159267000,&#39;0.10f&#39;) #小数点计数法,指定保留10位小数
&#39;3.1415926700&#39;
>>> format(3.14e+1000000,&#39;F&#39;)  #小数点计数法,无穷大转换成大小字母
&#39;INF&#39;

#g的格式化比较特殊,假设p为格式中指定的保留小数位数,先尝试采用科学计数法格式化,得到幂指数exp,如果-4<=exp<p,则采用小数计数法,并保留p-1-exp位小数,否则按小数计数法计数,并按p-1保留小数位数
>>> format(0.00003141566,&#39;.1g&#39;) #p=1,exp=-5 ==》 -4<=exp<p不成立,按科学计数法计数,保留0位小数点
&#39;3e-05&#39;
>>> format(0.00003141566,&#39;.2g&#39;) #p=1,exp=-5 ==》 -4<=exp<p不成立,按科学计数法计数,保留1位小数点
&#39;3.1e-05&#39;
>>> format(0.00003141566,&#39;.3g&#39;) #p=1,exp=-5 ==》 -4<=exp<p不成立,按科学计数法计数,保留2位小数点
&#39;3.14e-05&#39;
>>> format(0.00003141566,&#39;.3G&#39;) #p=1,exp=-5 ==》 -4<=exp<p不成立,按科学计数法计数,保留0位小数点,E使用大写
&#39;3.14E-05&#39;
>>> format(3.1415926777,&#39;.1g&#39;) #p=1,exp=0 ==》 -4<=exp<p成立,按小数计数法计数,保留0位小数点
&#39;3&#39;
>>> format(3.1415926777,&#39;.2g&#39;) #p=1,exp=0 ==》 -4<=exp<p成立,按小数计数法计数,保留1位小数点
&#39;3.1&#39;
>>> format(3.1415926777,&#39;.3g&#39;) #p=1,exp=0 ==》 -4<=exp<p成立,按小数计数法计数,保留2位小数点
&#39;3.14&#39;
>>> format(0.00003141566,&#39;.1n&#39;) #和g相同
&#39;3e-05&#39;
>>> format(0.00003141566,&#39;.3n&#39;) #和g相同
&#39;3.14e-05&#39;
>>> format(0.00003141566) #和g相同
&#39;3.141566e-05&#39;

Atas ialah kandungan terperinci Python内置format函数详细介绍. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn