详解Python数据类型、进制转换、字符串格式化的问题
作者:这个手刹不太灵儿 发布时间:2022-11-11 16:24:10
1. 整数、浮点数和复数
Python2中区分整型int、长整型long
Python3中只有统称为 整型int
浮点数
即带有小数点的数字,因为浮点数用二进制表示的,小数部分有时是无法表示的。是不精确的
float组成: 由整数位,小数点,小数位组成,也可以用科学计数法表示
Decimal
是精确的
from decimal import Decimal #从decimal 包导入Decimal 类
mydec = Decimal("3.22") #将字符串转换成decimal类型
print(mydec, type(mydec))
mydec2 = Decimal(3.22) #浮点型3.22 是不精确的,转换成decimal就是精确的
print(mydec2, type(mydec))
结果:3.22 <class 'decimal.Decimal'>
3.220000000000000195399252334027551114559173583984375 <class 'decimal.Decimal'>
复数
dir(a) 查看属性
a.imag 获取虚部,无论定义的时候是整型还是浮点型最终都会转换成浮点型
a.real 获取实部
>>> a = 4 + 5j
>>> a.imag
5.0
>>> a.real
4.0
2.进制转换
进制数字类型
二进制、八进制、十六进制都是整型
>>> a=0b11 二进制 binary
>>> type(a)
<class 'int'>
>>> b=0o11 八进制 octonary
>>> type(b)
<class 'int'>
>>> c=0x11 十六制 hexadecimal
>>> type(c)
<class 'int'>
整型进制操作
整型转换成2、8、16进制,得到的值是字符串类型
>>> num = 100
>>> bin(num) 整型转换成二进制,()里面只能是整型
任意进制转2进制, 接收一个int, 返回一个str
'0b1100100'
>>> oct(num) 任意进制转8进制, 接收一个int, 返回一个str
'0o144'
>>> hex(num) 任意进制转16进制, 接收一个int, 返回一个str
'0x64'
>>> int (0o11) 接收整型
9
>>> int("0o11",base=8) 接收整型,但要指定几进制
9
>>> int("11") 接收整型,可以不指定,因为它是一个数字
11
3. 字符串
3.1 转义字符
r标志:是输出原始字符串,不转义
3.2 字符串取值
下标取值法
从左0123456
从右-1 -2 -3 -4 -5
>>> a = 'abcdefghijklmnopq'
>>> a[0]
'a'
>>> a[-8]
'j'
切片取值法
str[start:end:step] 左闭右开
step 为正数 从左至右
step 为负数 从右至左
str[2:] 从左至右 第三个数开始
str[:7] 从左至右到第七位
str[::-1] 从右至左 步长为1
str[4::-2] 从第五个数开始从右至左 步长为2
>>> a = 'abcdefghijklmnopq' 一旦定义不可改变
>>> a[2:5]
'cde'
4. 字符串运算与转换
>>> str1="qqq"
>>> str2 = "lll"
>>> str1+str2 # 字符串拼接
'qqqlll'
>>> str3="abc"
>>> str3*3
'abcabcabc'字符串复制
>>> result = str(100) # int转换成字符串
>>> type(result)
<class 'str'>
>>> result
'100'
5. 字符串的常用方法
判断系列
演示:
>>> str7= "helloabc xx zz"
>>> str7.startswith("abc")
False
>>> str7.startswith("abc",5)
True
>>> str7.startswith("abc",5,7)
False
>>> str7.startswith("abc",5,8)
True
查找统计系列
len不是字符串的属性方法,不能通过.len的方式去计算长度
字符串转换类
>>> str7
'helloabc xx zz'
>>> str7.upper() 转大写
'HELLOABC XX ZZ'
>>> str7.title() 转标题格式
'Helloabc Xx Zz'
>>> str9 = str7.title().swapcase() 大小写互换
>>> str9
'hELLOABC xX zZ'
>>> str9 = "a b c d e f"
>>> str9.split() 默认按空格切割
['a', 'b', 'c', 'd', 'e', 'f']
>>> str10 = "a#b#c#d#e#f#g#h"
>>> str10.split("#")
['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h']
>>> str11 = str10.split("#")
>>> str11
['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h']
>>> "*".join(str11)
'a*b*c*d*e*f*g*h'
+和join的效率问题
+ 拼接效率比join低。+拼接,每一次出现都会在内存中开辟一个新的空间,所以效率低
6 . 字符串格式化
%格式化
语法格式:%[(name)][flags][width].[precision]typecode
(name):命名
flags: +,-,’ '或0。
+表示右对齐;-表示左对齐;
’ '为一个空格,表示在正数的左侧填充一个空格,从而与负数对齐,0表示使用0填充。
width表示显示宽度
precision表示小数点后精度
%s 一个萝卜一个坑,一一对应,不能多也不能少
演示:
结果
format格式化
num1 = 0.1416926 #转换成百分位
print("%.2f%% " % (num1 * 100))
f格式化
python2不支持这种写法
print(f"my name is {name},my age is {age}")
结果:my name is sc,my age is 4
print(f"my name is {name},my age is {age:*>10}")
结果:my name is sc,my age is *********4
练习
字符串的拼接方式
请计算出新拼接出来的字符串长度,并取出其中的第七个字符。
a = "字符串拼接1"
b = "字符串拼接2"
print("方式1:" + a + b)
print("方式2:%s%s" % (a, b))
print(f"方式3:{a}{b}")
print("方式4:{0}{1}".format(a, b))
c = a + b
print("新拼接的字符串长度为:", len(c))
print("第七个字符为:", c[6])
str1 = "8*y*cali*china**it*soft*linux*python"
count = str1.count("*")
list = str1.split("*")
str2 = "".join(list)
print("*" * count + str2)
将字符串"8ycalichina**itsoftlinuxpython"里的所有的*
号抽
取出来放到最前面,里面的字符串保持顺序不变
str1 = "8*y*cali*china**it*soft*linux*python"
count = str1.count("*")
list = str1.split("*")
str2 = "".join(list)
print("*" * count + str2)
7. 字符串拼接
print(“%s %s”%(str1,str2))
>>> str1 = "你好"
>>> str2 = "hejin"
>>> str1+str2 #方式1:加号拼接
'你好hejin'
>>> "".join([str1,str2]) #方式2:join拼接
'你好hejin'
>>> print("%s,%s"%(str1,str2)) #方式3:% 占位符
你好,hejin
>>> "{},{}".format(str1,str2) #方式4:format()
'你好,hejin'
>>> "{0},{1}".format(str1,str2) # 方式5
'你好,hejin'
>>> "{1},{0}".format(str1,str2)
'hejin,你好'
>>> "{a},{b}".format(a=str1,b=str2) # 方式6
'你好,hejin'
>>> "{b},{a}".format(a=str1,b=str2)
'hejin,你好'
>>> f"{str1},{str2}" # 方式7:f格式化
'你好,hejin'
练习:猜谁是小偷
嫌疑人A、B、C、D的笔录如下,其中三人为真,一人为假:
a:我不是小偷
b:C是小偷
c:小偷肯定是D
d:小偷肯定是D
lst = ["a", "b", "c", "d"]
for x in lst:
if ("a" != x) + ("c" == x) + ("d" == x) + ("d" != x) == 3:
print(f"{x}是小偷")
来源:https://blog.csdn.net/qq_40887651/article/details/120886633
猜你喜欢
- 这篇文章主要介绍了微信小程序转发事件实现解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考
- 前言本文的github仓库地址为: 替换照片人物背景项目(模型文件过大,不在仓库中)由于模型文件过大,没放在仓库中,本文下面有模型下载地址。
- 本文主要给大家介绍了关于webpack中publicPath路径问题的相关内容,分享出来供大家参考学习,下面来看看详细的介绍:output:
- 背景由于 python 自带的源下载速度非常慢,特别是安装一些库的时候,甚至有时会失败。pip国内的一些镜像 阿里云 http:
- 前言朋友提问:创建Word文档并插入市面上有很多图表绘制库,例如echarts和highcharts等等。对于这种由js动态绘制的图表,我们
- 前言python中图像处理相关库有很多,这里简单介绍PIL、cv2、scipy.imageio 、matplotlib.image、skim
- 人脸图像特征提取方法(一)HOG特征提取1、HOG简介Histogram of Oriented Gridients,缩写为HOG,是目前计
- 方法1:cmd环境下,用pip install selenium可能会很慢方法2:下载selenium安装包手动安装下载地址:https:/
- 一、前言恭喜你,学明白类,你已经学会所有基本知识了。这章算是一个娱乐篇,十分简单,了解一下pyautogui模块,这算是比较好学还趣味性十足
- 本文实例讲述了Python比较文件夹比另一同名文件夹多出的文件并复制出来的方法。分享给大家供大家参考。具体如下:这个东东本来是做来给公司数据
- 在看论文《Detecting Regions of Maximal Divergence for Spatio-Temporal Anoma
- 前言相信大家在工作无聊时,总想掏出手机,看看微博热搜在讨论什么有趣的话题,但又不方便直接打开微博浏览,今天就和大家分享一个有趣的小爬虫,定时
- 首先,啰嗦几句废话如下: (1)触发器(trigger)是个特殊的存储过程,它的执行并不需要我们去显式调用,而是由一些事件触发,这有点类似C
- 一.错误分类1. 语法错误也称为解析错误,发生在传统编程语言的编译时,在JavaScript中发生在解释时,这些错误是由代码中的意外字符直接
- 开发工具**Python版本:**3.6.4相关模块:pyecharts模块;以及一些Python自带的模块。环境搭建安装Python并添加
- 首先,我们需要着重介绍一些概念,以给你提供一些使这个“奇迹”得以发生的组成部分。太轻易地泄露伏笔对于讲故事来说不是个好的形式,所以那些不愿意
- 在学习python的时候,会有一些梗非常不适应,在此列举列表删除和多重循环退出的例子:列表删除里面的坑比如我们有一个列表里面有很多相同的值,
- 前言学会向程序中添加必要的注释,也是很重要的。注释不仅可以用来解释程序某些部分的作用和功能(用自然语言描述代码的功能),在必要时,还可以将代
- 一、介绍我们在项目的开发过程中应该会遇到这样的问题:我们的项目读取某个配置文件,然后才能按照配置的信息正常运行服务,当我们需要对修改服务的某
- 本文实例为大家分享了python实现五子棋双人对弈的具体代码,供大家参考,具体内容如下我用的是pygame模块来制作窗口代码如下:# 1、引