一.什么是数据类型?
什么是数据类型?
我们人类可以很容易的分清数字与字符的区别,但是计算机并不能呀,计算机虽然很强大,但从某种角度上看又很傻,除非你明确的告诉它,1是数字,“汉”是文字,否则它是分不清1和‘汉’的区别的,因此,在每个编程语言里都会有一个叫数据类型的东东,其实就是对常用的各种数据类型进行了明确的划分,你想让计算机进行数值运算,你就传数字给它,你想让他处理文字,就传字符串类型给他。Python中常用的数据类型有多种,如下:
整数(int) ,字符串(str),布尔值(bool),列表(list),元组(tuple),字典(dict),集合(set).
- int。数字:主要用于运算。1 ,2,3...
- bool。判断真假:True, False.
- str。简单少量的储存数据,并进行相应的操作。name = 'alex',
- tuple。只读,不能更改。(1,'alex')
- list:大量有序数据,[1,'ses',True,[1,2,3],{'name':'jinxin'}]
- dict:大量数据,且是关联性比较强的数据 {'name':'jinxin','age':18,'name_list':['张三','李四']}
二.基础数据类型。
2.1数字int。
int,就是咱们常见的数据类型,主要是用于葛总运算,加减乘数等
2.1.1 十进制二进制转换
十进制整数转换为二进制整数采用"除2取余,逆序排列"法。具体做法是:用2整除十进制整数,可以得到一个商和余数;再用2去除商,又会得到一个商和余数,如此进行,直到商为小于1时为止,然后把先得到的余数作为二进制数的低位有效位,后得到的余数作为二进制数的高位有效位,依次排列起来。
十进制小数转换成二进制小数采用"乘2取整,顺序排列"法。具体做法是:用2乘十进制小数,可以得到积,将积的整数部分取出,再用2乘余下的小数部分,又得到一个积,再将积的整数部分取出,如此进行,直到积中的小数部分为零,此时0或1为二进制的最后一位。或者达到所要求的精度为止。
二进制转化成十进制:
要从右到左用二进制的每个数去乘以2的相应次方,小数点后则是从左往右
例如:二进制数1101.01转化成十进制
1101.01(2)=1*20+0*21+1*22+1*23 +0*2-1+1*2-2=1+0+4+8+0+0.25=13.25(10)
所以总结起来通用公式为:
abcd.efg(2)=d*20+c*21+b*22+a*23+e*2-1+f*2-2+g*2-3(10)
或者是:
把二进制数首先写成加权系数展开式,然后按十进制加法规则求和。这种做法称为"按权相加"法。
此时,1101=8+4+0+1=13
再比如:二进制数100011转成十进制数可以看作这样:
数字中共有三个1 即第一位一个,第五位一个,第六位一个,然后对应十进制数即2的0次方+2的1次方+2的5次方, 即
100011=32+0+0+0+2+1=35
2.2.2 int操作方法
因为数字主要是用于计算,所以针对于数字可以使用的方法除了那些运算之外,没有什么经常会用的方法,python给咱们提供了一种方法:bit_length()就是帮助你快速的计算整数在内存中占用的二进制码的长度.
num = 10 print(num.bit_length()) # 当十进制用二进制表示时,最少使用的位数 # 运行结果: 4
2.2布尔值bool。
布尔值就两种:True,False。就是反应条件的正确与否。
真 1 True。
假 0 False。
这里补充一下int str bool 三者数据类型之间的转换。

1 # int ---> bool 2 i = 100 3 print(bool(i)) # True # 非零即True 4 i1 = 0 5 print(bool(i1)) # False 零即False 6 7 # bool ---> int 8 t = True 9 print(int(t)) # 1 True --> 1 10 t = False 11 print(int(t)) # 0 False --> 0 12 13 # int ---> str 14 i1 = 100 15 print(str(i1)) # '100' 16 17 # str ---> int # 全部由数字组成的字符串才可以转化成数字 18 s1 = '90' 19 print(int(s1)) # 90 20 21 # str ---> bool 22 s1 = '太白' 23 s2 = '' 24 print(bool(s1)) # True 非空即True 25 print(bool(s2)) # False 26 # bool ---> str 27 t1 = True 28 print(str(True)) # 'True'
2.3字符串str。
Python中凡是用引号引起来的数据可以称为字符串类型,组成字符串的每个元素称之为字符,将这些字符一个一个连接起来,然后在用引号起来就是字符串。
s1 = '李庆lqq' # 对于s1这个字符串来说,它由五个字符组成:李, 庆, l, q.q。
2.3.1、字符串的索引与切片。
组成字符串的字符从左至右,依次排列,他们都是有顺序的,就好比是部队的队列,从左至右依次报号(从零开始) :0,1,2,3....
索引即下标,就是字符串组成的元素从第一个开始,初始索引为0以此类推。
a = 'ABCDEFGHIJK' print(a[0]) print(a[3]) print(a[5]) print(a[7])
切片就是通过索引(索引:索引:步长)截取字符串的一段,形成新的字符串(原则就是顾头不顾尾)。
a = 'ABCDEFGHIJK' print(a[0:3]) # print(a[:3]) 从开头开始取0可以默认不写 print(a[2:5]) print(a[:]) #默认到最后 print(a[:-1]) # -1 是列表中最后一个元素的索引,但是要满足顾头不顾腚的原则,所以取不到K元素 print(a[:5:2]) #加步长 print(a[-1:-5:-2]) #反向加步长
2.3.2、字符串常用方法。
字符串除了可以用切片(步长)之外,还有一些其他的操作方法。

#字符串中的元素出现的个数。 # s='allqqjhhjsd' # s1 = s.count("a",0,4) # 可切片 # print(s1) a4 = "dkfjdkfasf54" #startswith() 判断是否以...开头 #endswith() 判断是否以...结尾 # ret4 = a4.endswith('jdk',3,6) # 顾头不顾尾 # print(ret4) # 返回的是布尔值 # ret5 = a4.startswith("kfj",1,4) # print(ret5) #split 以什么分割,最终形成一个列表此列表不含有这个分割的元素。 # s = 'title,Tilte,atre,'.split('t') # print(s) # s1 = 'title,Tilte,atre,'.split('t',1) # print(s1) #format的三种玩法 格式化输出 res='{} {} {}'.format('egon',18,'male') res='{1} {0} {1}'.format('egon',18,'male') res='{name} {age} {sex}'.format(sex='male',name='egon',age=18) #strip s='@@lqqdfs$$' s14 = s.strip('@') #默认去除前后的数据 s15 = s.rstrip('$') #去除右边的数据(包括空格) s16 = s.lstrip('@') #去除左边的数据(包括空格) s1=' @@lqqdfs$$ ' s17 = s.strip() #默认去除前后的空格 print(s14) print(s15) print(s16) print(s17) #replace:替换 # s = '来看待街坊邻居复合大师街坊法好的撒见客户' # s11 = s.replace('街坊','老王',1) # print(s11) #如果字符串中存在\t的话,expandtabs()方法会从\t开始向前补全8位,超过8位不足16位的补全16位 #l='sad\tdfsd' #s8=l.expandtabs() #print(s8) #####is系列 name='taibai123' print(name.isalnum()) #字符串由字母或数字组成 print(name.isalpha()) #字符串只由字母组成 print(name.isdecimal()) #字符串只由十进制组成 #寻找字符串中的元素是否存在 # s='lqqdfs' #s12=s.find('qq') #s13=s.index('d') #print(s12) # find 通过元素找索引,找不到返回-1,不会报错,找到返回0 # index通过元素找索引,找不到报错,找到返回0 #captalize,swapcase,title print(name.capitalize()) #首字母大写 print(name.swapcase()) #大小写翻转 msg='taibai say hi' print(msg.title()) #每个隔开(特殊字符或者数字)的单词首字母大写 # 居中,总长度,空白处填充 ret2 = a1.center(20,"*") print(ret2)