专栏首页python3万恶之源 - Python基础数据类型一

万恶之源 - Python基础数据类型一

整数

整数在Python中的关键字用int来表示; 整型在计算机中运于计算和比较

在32位机器上int的范围是:  -2**31~2**31-1,即-2147483648~2147483647

在64位机器上int的范围是: -2**63~2**63-1,即-9223372036854775808~9223372036854775807

在python3中所有的整数都是int类型. 但在python2中如果数据量比较大. 会使用long类型.

在python3中不存在long类型 整数可以进行的操作:

整数的加

a = 10
b = 20
print(a + b)

结果:
30

整数的减

a = 10
b = 20
print(b - a)

结果:
10

整数的乘

a = 10
b = 20
print(a * b)

结果:
200

整数的除

a = 10
b = 20
print(b / a)

结果:
2.0
# 注意点:当我们使用Python3的时候我们除法获取到时浮点数,也就是小数,但是使用Python2的时候使用除法获取的就是整数

整数的整除

a = 10
b = 20
print(b // a)

结果:
2

整数的取余

a = 5
b = 2
print(a % b)

结果:
1

整数的次方(幂)

a = 5
b = 2
print(a ** b)

结果:
25

注意点: 在Python2中存在long(长整型) 但是在Python3中long(长整型)不存在

布尔值

布尔值(bool) 判断真假; 取值只有 True False 

转换问题:

str ==> int
n = int('22')
print(n)
结果:
22
#注意点:字符串中的内容必须是阿拉伯数字才能强行转换
int ==> str
n = str(22)
print(n)
结果:
22
int ==> bool
n = bool(4)  # bool(-1) 结果也是True
print(n)
结果:
True
注意点: 使用bool转换的时候只要是非0的都为True
bool ==> int
n = int(True) # int(False) 结果是0
print(n)
结果:
1
bool ==> str
n = str(True)
print(n)
结果:
True   
注意点: 只要字符串中的内容不为空,所得到的结果就是True
str ==> bool
n = str(True)
print(n)
结果:
True 

字符串

字符串(str)   字符串, 可以保存少量数据并进行相应的操作 

在第一天的时候咱们简单的认识了下字符串,今天我们好好的来认识一下这个让你又喜又优的字符串

字符串是可以存储一些数据,方便我们使用

字符串加

a = '世界'
b = '你好'
print(a + b)
结果:
世界你好

通过刚刚我们的测试发现字符串也是可以进行加法操作的,字符串相加其实有个专业的名词 --- 字符串拼接;相加的规则就是必须都是字符串才能相加

字符串中是不能进行减法和除法操作的,通过这句话就能得知字符串是可以进行乘法操作的,我们立马来看一下:

字符串乘

a = '坚强'
print(a * 8)
结果:
坚强坚强坚强坚强坚强坚强坚强坚强

字符串的乘法就是将多个字符串拼接到一起,乘法的规则:只能是字符串和数字相乘

 索引(下标)

大家在上学的时候就会发现在一个班有的同学的名字是一样的,最后大家为了好区分就有了外号,我们每个人都有个学号,其实学校就是为了防止重名找错人,

学号就是一种能够保证唯一且准确的手段,这种手段在计算机中存在,这种手段叫做索引,也有人称之为下标.注意:索引如果操作会报错

图上就是对"meet"字符串进行索引排号,其实图上有一点大家不难看出m对应的是数字0,如果让我们人来给排号.下意识的会从1开始.

因为我们从小的时候就是从1开始数数的,但是在计算机中数数确实要从0开始,其实这个点也是对程序的入门.

以后在碰到这种类似的问题我们就知道是从0开始计数,废话不多说我们来看看,我说的到底行不行.

name = 'meet'
# 索引  0123
print(name[0])

结果:
m  

细心的老铁们会发现这[ ]是干啥的,这个是一个查找,我不知道字符串中第一个是什么,但是我知道第一个的索引,我就可以通过这个方式来查看

比方:我不知道这个学生叫什么,但是我知道他的学号.我也可以通过学号找到这个同学.

图上这个是从左到右的一种排序,其实还有一种从右像左的排序,看下图:

这个查看和上边的一样,只不过是索引排序的方式不一样,他这次的排列序号是从右向左并且还是以-1开始,这里的-1其实就是表示我们的倒数第一个

-2表示倒数第二个,这样排列,如果我们的字符串比较长的时候想要获取最后一个就完全可以使用-1,看以下示例:

name = 'meet'
# 索引 -4-3-2-1
print(name[-1])

结果:
t

告诉大家一个小技巧,当开始的是我们不能明确的区分这个字符串中的每个索引的时候,我们就先把每个字母对应的索引写下来,这样就方便我们查找

上边我们说完了索引,你们就以为完事了是吗?不是滴,咱们还有来个内容没有进行讲解,分别是切片和步长

切片

切片又是什么呢?我们先来看一个示例:

name = 'meet'
# 索引  0123
print(name[0:3])

结果:
mee

[第一个位置是开始:第二个位置是终止]中间必须使用分号,这样的写法就是从索引0开始获取到索引3结束  

这个结果是不是和大家想的有点出入啊,大家肯定认为获取到的内容是meet,但是为什么是mee呢,因为终止的索引是不包含的获取的是这个区间的内容

想想咱们在买肉的时候,有一个块整肉,这块整肉就后边有点肥,不想要是不是就让老板给切掉了,我们就买前边的部分啊.在生活中这种神操作就是切片

我也知道你们刚接过这些东西,使用起来不是很熟悉,尤其是切片这部分,在悄悄的告诉你们个小技巧,下次当看到切片中终止位置的时候把这个数减一就ok啦

步长

步长又是什么呢?先看示例:

name = 'meet'
# 索引  0123
print(name[0:3:1])

结果:
mee 

发现我在中括号中最后一个位置写了一个东西,也没什么变化,是的没有变化,因为我们不写的时候他默认就是1,我们换个数字在来看看

name = 'meet'
# 索引  0123
print(name[0:3:2])

结果:
me  

这又是啥情况呢?想想我开始告诉大家的中括号里第一个参数是起始位置,第二参数是终止位置,第三个参数现在告诉大家是步长(每次走几步)

当步长设置为2的时候,咱们只需要用起始位置0加上步长2,结果也就2然后在把索引为2的找到,2在加上步长2就是4,当要查找索引4是发现终止索引就是3,

所有不会进行查找.最终的结果就是me.

练习1

s = 'Python最NB'

获取s字符串中前3个内容

获取s字符串中第3个内容

获取s字符串中后3个内容

获取s字符串中第3个到第8个

获取s字符串中第2个到最后一个

获取s字符串中第1,3,5个内容

获取s字符串中第2,4,6个内容

获取s字符串中所有内容

获取s字符串中第4个到最后一个,每2个取一个

获取s字符串中倒数第5个到最开始,每3个取一个  
s = 'Python最NB'

# 获取s字符串中前3个内容
print(s[0:2])
# 获取s字符串中后3个内容
print(s[6:9])
# 获取s字符串中第3个到第8个
print(s[2:8])
# 获取s字符串中第2个到最后一个
print(s[2:])
# 获取s字符串中第1,3,5个内容
print(s[0:6:2])
# 获取s字符串中第2,4,6个内容
print(s[1:7:2])
# 获取s字符串中所有内容
print(s[:])
# 获取s字符串中第4个到最后一个,每2个取一个
print(s[3::2])
# 获取s字符串中倒数第5个到最开始,每3个取一个
print(s[-5::-3])

答案

练习2

判断⼀句话是否是回⽂. 回⽂: 正着念和反着念是⼀样的. 例如, 上海⾃来⽔来⾃海上

练习3

有字符串s = "123a4b5c"

通过对s切片形成新的字符串s1,s1 = "123"
通过对s切片形成新的字符串s2,s2 = "a4b"
通过对s切片形成新的字符串s3,s3 = "1345"
通过对s切片形成字符串s4,s4 = "2ab"
通过对s切片形成字符串s5,s5 = "c"
通过对s切片形成字符串s6,s6 = "ba2" 

字符串方法详解

全部大写

name = 'alex'
new_name = name.upper()
print(new_name)
# 把这个字符串全部变成大写

全部小写

name = 'ALEX'
new_name = name.lower()
print(new_name)
# 把这个字符串全部变成小写  

应用场景:

# 字符串大小写做验证码
y_z_m = 'O98k'
y_z_m_input = input("请输入验证码(O98k)")
user = input('请输入账号:')
pwd = input('请输入密码:')
if y_z_m == y_z_m_input:
    if user == 'alex' and pwd == '8520':
        print('登陆成功!')
    else:
        print('登录失败')
else:
    print('验证码错误!')

首字母大写  

name = 'alexdasx'
new_name = name.capitalize()
print(new_name)
# 首字母大写

练习

移除name变量左边的"al"并输出处理结果
移除name变量右面的"Nb",并输出处理结果
将 name 变量对应的值变大写,并输出结果
将 name 变量对应的值变小写,并输出结果
将name变量对应的值首字母"a"大写,并输出结果 

以什么开头  

name = 'alex'
new_name = name.startswith('a')
if new_name:
    print('是以a开头')
# 判断这是不是字符串是不是以a开头的

以什么结尾  

name = 'alex'
new_name = name.endswith('x')
if new_name:
    print('是以x结尾')
# 判断这是不是字符串是不是以x结尾的

统计出现的次数

name = 'alexdasx'
new_name = name.count('a')
print(new_name)
# 统计name这个字符串中a出现的次数  

查找下标  

name = 'alexdasx'
new_name = name.find('e')
print(new_name)
# 通过元素查找下标,不存在就返回-1

查找下标  

name = 'alexdasx'
new_name = name.index('e')
print(new_name)
# 通过元素查找下标,不存在就报错

练习

判断 name 变量是否以 "al" 开头,并输出结果
判断name变量是否以"Nb"结尾,并输出结果
判断name变量对应的值字母"l"出现几次,并输出结果
从name变量对应的值中找到"N"对应的索引(如果找不到则报错),并输出结果
从name变量对应的值中找到"N"对应的索引(如果找不到则返回-1)输出结果
实现一个整数加法计算器(两个数相加):
如:content = input("请输入内容:") 用户输入:5+9或5+ 9或5 + 9,然后进行分割再进行计算。

实现一个整数加法计算器(多个数相加):
如:content = input("请输入内容:") 用户输入:5+9+6 +12+  13,然后进行分割再进行计算。

字符串替换  

name = 'alexdasx'
new_name = name.replace('sx','sb')
print(new_name)
# 替换字符串中的内容

去除头尾两边的空格  

name = ' alexdasx '
new_name = name.strip()
print(new_name)

# 去除头尾俩遍的空格和换行符

分割

name = 'alexdasx'
new_name = name.split("x")
print(new_name)
#通过x将字符串name进行切割

字符串格式化

name = 'alexdasx{}'
new_name = name.format('说的对')
print(new_name)
# 字符串格式化 

练习

将 name 变量对应的值中的 所有的"l" 替换为 "p",并输出结果 
将name变量对应的值中的第一个"l"替换成"p",并输出结果
将 name 变量对应的值根据 所有的"l" 分割,并输出结果。
将name变量对应的值根据第一个"l"分割,并输出结果。 
请输出 name 变量对应的值的第 2 个字符? 
请输出 name 变量对应的值的前 3 个字符? 
请输出 name 变量对应的值的后 2 个字符?
请输出 name 变量对应的值中 "e" 所在索引位置(两个e都找)?

is系列

 判断是不是阿拉伯数字,返回的是布尔值

name = 'alexdasx'
new_name = name.isdigit()
print(new_name)
# 判断是不是阿拉伯数字,返回结果是布尔值 

判断是不是数字和字母,返回的是布尔值

name = 'alex7dasx'
new_name = name.isalnum()
print(new_name)
# 判断是不是字母和数字,返回结果是布尔值

判断是不是纯字母及汉字,返回的是布尔值

name = 'alexdasx'
new_name = name.isalpha()
print(new_name)
# 判断是不是字母和数字,返回结果是布尔值

练习

输⼊⼀个字符串,要求判断在这个字符串中⼤写字⺟,⼩写字⺟,数字, 其它字符共出现了多少次,并输出  

获取长度

目前我们写的内容还比较少,如果有一个很长很长的字符串,如果要是一个一个数是不是很累呢,Python给咱们提供了一个方法就是获取长度的.

长度获取示例:

name = "Meet"
print(len(name))

结果:
4 

我们现在能够轻松的获取到到长度,现在我有这么一个字符串 name = "Meet",请使用while循环获取到字符串中每个元素并打印,效果图入下:

name = "Meet"

count = 0
while count < len(name):
    print(name[count])
    count = count + 1

以上这个写法是没有问题的,你们来看这个会不会简单些

name = "Meet"
for i in name:
    print(i)

上边的这个东西叫做for循环, for是关键字    i是一个变量    后边的name是要被循环的内容,他会把这个name指向的字符串里的每个元素打印出来

 for循环是可以循环的数据结构:

  • 字符串(str)
  • 列   表(list)
  • 元   祖(tuple)
  • 字   典(dict)
  • 集   合(set)

唯独不能进行循环的就是 整型(int)和布尔值(bool)

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • python中的%s%是什么意思

    Python支持将值格式化为字符串。虽然这可以包括非常复杂的表达式,但最基本的用法是将值插入到%s 占位符的字符串中。

    py3study
  • 【python学习】新手基础程序练习(二

    py3study
  • python 实战 登录注册

    py3study
  • 03 实战 Ansible-Playbook之初始化服务器

    推荐专栏:https://blog.51cto.com/cloumn/detail/83from_distribution=VQcJVApVVQwxUwIHVQ...

    alexhuiwang
  • 动手实现一个AMD模块加载器(三)

    在上一篇文章中,我们的AMD模块加载器基本已经能够使用了,但是还不够,因为我们没有允许匿名模块,以及没有依赖等情况。实际上在amd的规范中规定的就是define...

    用户1515472
  • python中的%s%是什么意思

    Python支持将值格式化为字符串。虽然这可以包括非常复杂的表达式,但最基本的用法是将值插入到%s 占位符的字符串中。

    py3study
  • 网站搭建-django-学习成绩管理-06-数据库操作之ORM-1

    系统:Windows 7 语言版本:Anaconda3-4.3.0.1-Windows-x86_64 编辑器:pycharm-community-2016.3....

    zishendianxia
  • python 实战 登录注册

    py3study
  • jQuery中调用JSON和XML数据--jQuery基础知识点(6)

    版权声明:本文为博主原创文章,遵循 CC 4.0 by-sa 版权协议,转载请附上原文出处链接和本声明。

    奋飛
  • Jsp技术介绍

    roobtyan

扫码关注云+社区

领取腾讯云代金券