本站消息

站长简介/公众号


站长简介:逗比程序员,理工宅男,前每日优鲜python全栈开发工程师,利用周末时间开发出本站,欢迎关注我的微信公众号:幽默盒子,一个专注于搞笑,分享快乐的公众号

  价值13000svip视频教程,python大神匠心打造,零基础python开发工程师视频教程全套,基础+进阶+项目实战,包含课件和源码

  出租广告位,需要合作请联系站长

+关注
已关注

分类  

暂无分类

标签  

暂无标签

日期归档  

2020-07(10)

2020-08(50)

python基础数据类型

发布于2020-08-28 06:29     阅读(471)     评论(0)     点赞(2)     收藏(0)



一.什么是数据类型?

什么是数据类型?

  我们人类可以很容易的分清数字与字符的区别,但是计算机并不能呀,计算机虽然很强大,但从某种角度上看又很傻,除非你明确的告诉它,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'
View Code

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)
字符串常用方法

 

原文链接:https://www.cnblogs.com/LQ-ZL/p/13572920.html






所属网站分类: 技术文章 > 博客

作者:丸子

链接:https://www.pythonheidong.com/blog/article/496705/4132787d4862799a9ca4/

来源:python黑洞网

任何形式的转载都请注明出处,如有侵权 一经发现 必将追究其法律责任

2 0
收藏该文
已收藏

评论内容:(最多支持255个字符)