Python小白学习之路(九)—【字符串格式化】【百分号方式】【format方式】
写在前面:
最近的事情好像有很多。李咏的离去,让我觉得很突然,仿佛印象中就是主持节目的他,看着他和哈文的爱情,很是感动。离去,没有什么抱怨,只是遗憾。
总会感慨,时光的流逝。
好像真的很快,转眼间,我都这么大了。
最近,刘某人总说的一句话,小时候虽然很穷,但是很快乐
而现在,不仅仅是穷,而且还不快乐
想想还真是(手动捂脸)
最近身体不舒服,好像学习也停滞不前。
好好加油!感谢每一天努力的自己,好好珍惜身边的一切
希望快快好起来,做那个活力满满的小伙郭
昨晚半夜不知道是肚子疼醒,还是做噩梦了。
满头大汗醒来,
觉得自己一直就是一个长不大的孩子
身边的人陆陆续续结婚生孩子
我还在学校晃来晃去,估计我爸妈都比我着急
哈哈哈
说了一通(也不知道要表达什么)
整理整理学习笔记,回去休息啦。晚安,为了梦想而努力的人们
每一个为了梦想而努力的陌生人,加油!
字符串格式化
Python的字符串格式化有两种方式: 百分号方式、format方式
一、百分号方式
格式:
%[(name)][flags][width].[precision]typecode
- (name) 可选,用于选择指定的key
- flags 可选,可供选择的值有:
- + 右对齐;正数前加正好,负数前加负号;
- - 左对齐;正数前无符号,负数前加负号;
- 空格 右对齐;正数前加空格,负数前加负号;
- 0 右对齐;正数前无符号,负数前加负号;用0填充空白处
- width 可选,占有宽度
- .precision 可选,小数点后保留的位数
- typecode 必选
- s,获取传入对象的__str__方法的返回值,并将其格式化到指定位置
- r,获取传入对象的__repr__方法的返回值,并将其格式化到指定位置
- c,整数:将数字转换成其unicode对应的值,10进制范围为 0 <= i <= 1114111(py2.7则只支持0-255);字符:将字符添加到指定位置
- o,将整数转换成 八 进制表示,并将其格式化到指定位置
- x,将整数转换成十六进制表示,并将其格式化到指定位置
- d,将整数、浮点数转换成 十 进制表示,并将其格式化到指定位置
- e,将整数、浮点数转换成科学计数法,并将其格式化到指定位置(小写e)
- E,将整数、浮点数转换成科学计数法,并将其格式化到指定位置(大写E)
- f, 将整数、浮点数转换成浮点数表示,并将其格式化到指定位置(默认保留小数点后6位)
- F,同上
- g,自动调整将整数、浮点数转换成 浮点型或科学计数法表示(超过6位数用科学计数法),并将其格式化到指定位置(如果是科学计数则是e;)
- G,自动调整将整数、浮点数转换成 浮点型或科学计数法表示(超过6位数用科学计数法),并将其格式化到指定位置(如果是科学计数则是E;)
- %,当字符串中存在格式化标志时,需要用 %%表示一个百分号
常用格式化:
1.%typecode
%s 获取传入对象的__str__方法的返回值,并将其格式化到指定位置
(可以接受任何数据类型,比较万能,但是为了提高程序可读性,我们选择对应的格式化方式)
tpl = "i am %s" % "xhg"
print(tpl)
#执行结果
i am xhg tp2 = "i am %s, i am from %s" % ("xhg","China")
print(tp2)
#执行结果
i am xhg, i am from China
2.%typecode
%d 将整数、浮点数转换成 十 进制表示,并将其格式化到指定位置
tpl = "i am %s age %d" % ("xhg", 18)
print(tpl)
#执行结果
i am xhg age 18
3.%[(name)]typecode
(name) 可选,用于选择指定的key
tpl = "i am %(name)s age %(age)d" % {"name": "xhg", "age": 18}
print(tpl)
#执行结果
i am xhg age 18
4.%.[precision]typecode
.precision 可选,小数点后保留的位数
f, 将整数、浮点数转换成浮点数表示,并将其格式化到指定位置(默认保留小数点后6位)
tpl = "percent %.2f" % 99.97623
print(tpl)
#执行结果
percent 99.98
5.%[(name)].[precision]typecode
(name) 可选,用于选择指定的key
.precision 可选,小数点后保留的位数
f, 将整数、浮点数转换成浮点数表示,并将其格式化到指定位置(默认保留小数点后6位)
tpl = "i am %(pp).2f" % {"pp": 123.425556, }
print(tpl)
#执行结果
i am 123.43
6.%,当字符串中存在格式化标志时,需要用 %%表示一个百分号
tpl = "i am %(pp).2f %%" % {"pp": 123.425556, }
print(tpl)
#执行结果
i am 123.43 %
二、Format方式
格式:
[[fill]align][sign][#][0][width][,][.precision][type]
- fill 【可选】空白处填充的字符
- align 【可选】对齐方式(需配合width使用)
- <,内容左对齐
- >,内容右对齐(默认)
- =,内容右对齐,将符号放置在填充字符的左侧,且只对数字类型有效。 即使:符号+填充物+数字
- ^,内容居中
- sign 【可选】有无符号数字
- +,正号加正,负号加负;
- -,正号不变,负号加负;
- 空格 ,正号空格,负号加负;
- # 【可选】对于二进制、八进制、十六进制,如果加上#,会显示 0b/0o/0x,否则不显示
- , 【可选】为数字添加分隔符,如:1,000,000
- width 【可选】格式化位所占宽度
- .precision 【可选】小数位保留精度
- type 【可选】格式化类型
- 传入” 字符串类型 “的参数
- s,格式化字符串类型数据
- 空白,未指定类型,则默认是None,同s
- 传入“ 整数类型 ”的参数
- b,将10进制整数自动转换成2进制表示然后格式化
- c,将10进制整数自动转换为其对应的unicode字符
- d,十进制整数
- o,将10进制整数自动转换成8进制表示然后格式化;
- x,将10进制整数自动转换成16进制表示然后格式化(小写x)
- X,将10进制整数自动转换成16进制表示然后格式化(大写X)
- 传入“ 浮点型或小数类型 ”的参数
- e, 转换为科学计数法(小写e)表示,然后格式化;
- E, 转换为科学计数法(大写E)表示,然后格式化;
- f , 转换为浮点型(默认小数点后保留6位)表示,然后格式化;
- F, 转换为浮点型(默认小数点后保留6位)表示,然后格式化;
- g, 自动在e和f中切换
- G, 自动在E和F中切换
- %,显示百分比(默认显示小数点后6位)
- 传入” 字符串类型 “的参数
常用格式化:
1.格式化的数据要一一对应,前后数据个数不一致,则报错
tpl = "i am {}, age {}, {}".format("seven", 18, 'alex')
print(tpl)
#执行结果
i am seven, age 18, alex
2.传入的数据以列表形式传入,用*表示
tpl = "i am {}, age {}, {}".format(*["seven", 18, 'alex'])
print(tpl)
#执行结果
i am seven, age 18, alex
3.将seven赋值给所有位置为0的占位符
tpl = "i am {0}, age {1}, really {0}".format("seven", 18)
print(tpl)
#执行结果
i am seven, age 18, really seven
4.传入的数据以列表形式传入,用*表示
tpl = "i am {0}, age {1}, really {0}".format(*["seven", 18])
print(tpl)
#执行结果
i am seven, age 18, really seven
5.将"seven"赋值给所有name
tpl = "i am {name}, age {age}, really {name}".format(name=seven, age=18)
print(tpl)
#执行结果
i am seven, age 18, really seven
6.传入的数据以字典形式传入,用**表示
tpl = "i am {name}, age {age}, really {name}".format(**{"name": "seven", "age": 18})
print(tpl)
#执行结果
i am seven, age 18, really seven
7.m[n]代表第m个元素中的第n个元素,利用索引来为占位符赋值
tpl = "i am {1[0]}, age {0[1]}, really {2[2]}".format([1, 2, 3], [11, 22, 33],[44,55,66])
print(tpl)
#执行结果
i am 11, age 2, really 66
8.s,格式化字符串类型数据;d,十进制整数;f , 转换为浮点型(默认小数点后保留6位)表示,然后格式化
tpl = "i am {:s}, age {:d}, money {:f}".format("seven", 18, 88888.1)
print(tpl)
#执行结果
i am seven, age 18, money 88888.100000
9.传入的数据以列表形式传入,用*表示
tpl = "i am {:s}, age {:d}".format(*["seven", 18])
print(tpl)
#执行结果
i am seven, age 18
10.{name:s}传入的name数据的类型是字符串;{age:d}传入的age数据的类型是十进制整数
tpl = "i am {name:s}, age {age:d}".format(name="seven", age=18)
print(tpl)
#执行结果
i am seven, age 18
11.传入的数据以字典形式传入,用**表示
tpl = "i am {name:s}, age {age:d}".format(**{"name": "seven", "age": 18})
print(tpl)
#执行结果
i am seven, age 18
12.
b,将10进制整数自动转换成2进制表示然后格式化
d,十进制整数o,将10进制整数自动转换成8进制表示然后格式化;
x,将10进制整数自动转换成16进制表示然后格式化(小写x)
X,将10进制整数自动转换成16进制表示然后格式化(大写X)
%,显示百分比(默认显示小数点后6位)
tpl = "numbers: {:b},{:o},{:d},{:x},{:X}, {:%}".format(15, 15, 15, 15, 15, 15.87623, 2)
print(tpl)
#执行结果
numbers: 1111,17,15,f,F, 1587.623000%
13.将15赋值给每一个位置为0的占位符
tpl = "numbers: {0:b},{0:o},{0:d},{0:x},{0:X}, {0:%}".format(15)
print(tpl)
#执行结果
numbers: 1111,17,15,f,F, 1500.000000%
14.将15赋值给num
tpl = "numbers: {num:b},{num:o},{num:d},{num:x},{num:X}, {num:%}".format(num=15)
print(tpl)
#执行结果
numbers: 1111,17,15,f,F, 1500.000000%
Python小白学习之路(九)—【字符串格式化】【百分号方式】【format方式】的更多相关文章
- Python小白学习之路(十六)—【内置函数一】
将68个内置函数按照其功能分为了10类,分别是: 数学运算(7个) abs() divmod() max() min() pow() round() sum() 类型转换(24个) bo ...
- Python小白学习之路(三)—【数字功能】【字符串功能】
数字(int)常见功能 在网络课上,老师把这些功能称为神奇的魔法,想要揭开魔法神奇的面纱,想要看看有什么招数,在Pycharm里敲击三个字母(int),按住Ctrl,将鼠标点在int上,这时鼠标会变成 ...
- Python小白学习之路(十九)—【文件操作步骤】【文件操作模式】
一.文件操作步骤 step1:打开文件,得到文件句柄并赋值给一个变量step2:通过句柄对文件进行操作step3:关闭文件 举例: a = open('hello world', 'r', encod ...
- Python小白学习之路(十八)—【内置函数三】
一.对象操作 help() 功能:返回目标对象的帮助信息 举例: print(help(input)) #执行结果 Help on built-in function input in module ...
- Python小白学习之路(四)——第一次练习题
写在前面: 今天下雪了呢!连着两天都没有更新学习记录. 我没有偷懒呢.做了一天的练习题,昨天学的内容还没总结完,太累了就回去睡觉了 连续一周早起,强大的内心也无法支撑我疲惫的身体 今天早起做了整理.加 ...
- Python小白学习之路(二)—【Pycharm安装与配置】【创建项目】【运算符】【数据类型】
写在前面: 第二天的学习,感觉比昨天学习相对轻松一些,但是对于我这个编程语言功底很弱的人来说,还是稍稍微有些.....哈尔滨的天气一天天冷了下来,还飘着小雨,不过还是挺有意境的.充实而又忙碌的生活,让 ...
- Python小白学习之路(二十)—【打开文件的模式二】【文件的其他操作】
打开文件的模式(二) 对于非文本文件,我们只能使用b模式,"b"表示以字节的方式操作(而所有文件也都是以字节的形式存储的,使用这种模式无需考虑文本文件的字符编码.图片文件的jgp格 ...
- Python小白学习之路(十五)—【map()函数】【filter()函数】【reduce()函数】
一.map()函数 map()是 Python 内置的高阶函数 有两个参数,第一个是接收一个函数 f(匿名函数或者自定义函数都OK啦):第二个参数是一个 可迭代对象 功能是通过把函数 f 依次作用在 ...
- Python小白学习之路(二十一)—【迭代器】
迭代器 1.迭代器协议 对象必须提供一个 next 方法,执行该方法要么返回迭代中的下一项,要么就引起一个Stoplteration异常,以终止迭代(只能往后走不能往前退) 2.可迭代对象 实现了迭代 ...
随机推荐
- 【Linux】Jenkins配置和使用(二)
摘要 本章介绍Jenkins的简单使用,关于Jenkins的安装,参照[Linux]Jenkins安装(一) 事例说明:在linux环境下,安装的jenkins,集成svn,tomcat的环境,项目是 ...
- 2018.06.29 NOIP模拟 排列(线段树)
排列(premu.cpp) [题目描述] 对于一个 1 到 n 的排列,逆序数的定义为:排列中第 i 位 ai的逆序数就是 a1-ai-1中比 ai大的数的个数.另外用 pi表示 a1,-,ai的逆序 ...
- hadoop学习笔记(一):概念和组成
一.什么是hadoop Apache Hadoop是一款支持数据密集型分布式应用并以Apache 2.0许可协议发布的开源软件框架.它支持在商品硬件构建的大型集群上运行的应用程序.Hadoop是根据G ...
- 20170906工作日记--volley源码的相关方法细节学习
1. 在StringRequest类中的75行--new String();使用方法 /** * 工作线程将会调用这个方法 * @param response Response from the ne ...
- Tensorflow currently has no official prebuild for your CUDA, cuDNN combination.
INFO CUDA version: 10. ERROR cuDNN not found. See https://github.com/deepfakes/faceswap/blob/master/ ...
- 第二届普适计算和信号处理及应用国际会议论文2016年 The 2nd Conference on Pervasive Computing, Signal Processing and Applications(PCSPA, 2016)
A New Method for Mutual Coupling Correction of Array Output Signal 一种阵列输出信号互耦校正的新方法 Research of Robu ...
- MySQL性能调优与架构设计——第12章 可扩展设计的基本原则
第12章 可扩展设计的基本原则 前言: 随着信息量的飞速增加,硬件设备的发展已经慢慢的无法跟上应用系统对处理能力的要求了.此时,我们如何来解决系统对性能的要求?只有一个办法,那就是通过改造系统的架构体 ...
- python网络编程应用(一)
在之前的一篇博客<python网络编程基础>中介绍了socket.socket()函数及其应用,其实socket模块中还有很多属性可供网络应用程序使用.这里将详细讲解一下socket模块 ...
- windows7,windows8 64位系统 IIS7.0配置.net网站时报错:未能加载文件或程序集“XXX”或它的某一个依赖项。试图加载格式不正确的程序。
背景: 在64位的操作系统中, IIS7.0配置.net网站时报错:未能加载文件或程序集“XXX”或它的某一个依赖项.试图加载格式不正确的程序. 解决办法: 把iis 对应的应用程序池 --高级设置- ...
- Android-Java-IO流概述
IO:I:Input输入 O:Output输出 IO流: IO:用于处理设备上数据的一种技术,处理设备上数据包括(Input / Output) ,设备指的是:内存,硬盘,U盘,打印机,等等..... ...