文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

python3--基础数据类型

2023-01-30 21:58

关注

python基础二(基础数据类型)

1.什么是数据?

  x=10,10是我们要存储的数据

2.为何数据要分不同的类型

  数据是用来表达状态的,不同的状态就应该用不同的类型数据去表示

3.数据类型

数字,字符串,列表,元组,字典,集合


数字int

数字主要是计算机用的,使用方法并不是很多,就记住一种就可以了

#bit_length() 当十进制用二进制表示时,最少使用的位数

v = 11

data = v.bit_length()

print(data)

结果为: 4


布尔值bool

布尔值就两种:True,False。就是反应条件的正确与否。

真 1 True

假 0 False


字符串str

字符串的索引与切片

索引即下标,就是字符串组成的元素从第一个开始,初始索引为0以此类推

a = 'ABCDEFGHIJK'
print(a[0])
print(a[3])
print(a[5])
print(a[7])

结果为

blob.png

切片就是通过索引(索引:索引:步长)截取字符串的一段,形成新的字符串(原则就是顾头不顾尾)

a = 'ABCDEFGHIJK'
print(a[0:3])
print(a[2:5])
print(a[0:]) #默认到最后
print(a[0:-1]) #-1就是最后一个
print(a[0:5:2]) #2指步长
print(a[5:0:-2]) #反向加步长

输出为

blob.png


字符串常用方法

#captalize,swapcase,title

name = 'hello world Sam'
print(name.capitalize()) # capitalize首字母大写
print(name.swapcase()) # swapcase大小写翻转
msg = 'egon say hi'
print(msg.title()) # title每个单词的首字母大写

结果为

blob.png


#内容居中,总长度,空白处填充

tmp = 'username'
print(tmp.center(20))  # 20为总长度,内容居中
print(tmp.center(20, '#')) # #号为填充的符号

结果为:

blob.png


#字符串中元素出现的个数

tmp1 = 'www.py3study.com'
print(tmp1.count("w")) #字符串tmp1中w出现的次数
print(tmp1.count("p", 0, -1)) #切片的方式数tmp1中p出现的次数

结果为:

blob.png


#\t前面的补全

#默认将一个tab键变成8个空格,如果tab前面的字符长度不足8个,则补全8个,如果tab键前面的字符长度超过8个不足16个,则补全16个,以此类推每次补全8个

a2 = '\thqw\t'
print(a2.expandtabs())

结果为

blob.png


#startswith 判断是否以...开头,结果返回布尔值

#endswith   判断是否以...结尾,结果返回布尔值

tmp2 = 'abcdefas210'
print(tmp2.startswith("abc", 1, 5))
print(tmp2.endswith("s210"))

结果为

blob.png


#寻找字符串中的元素是否存在

tmp3 = 'abcdabfd'
# find返回找到元素的索引,如果找不到返回-1
print(tmp3.find("abc", 0, 5))
print(tmp3.find("aa", 0, 5))
# index返回找到元素的索引,如果找不到就报错
print(tmp3.index("abc", 0, 5))

结果为

blob.png


# split以什么分割,最终形成一个列表,此列表不含有这个分割的元素

tmp4 = 'sam,tom,jack'
print(tmp4.split(','))
tmp5 = 'title,Tilte,atre'
print(tmp5.split('t', 1))

结果为

blob.png


# format的三种玩法,格式化输出

print('{},{},{}'.format('sam', '18', 'loop'))
print('{1},{0},{1}'.format('tom', '16'))
print('{name},{age},{sex}'.format(sex='loop',name='jack',age='15'))

结果为

blob.png


# strip去除左右两边的空格,换行,tab字符

name1 = '\nusername\n'
name2 = ' password '
name3 = '   Linux   '
name4 = 'Hello world'
print(name1.strip())
print(name2.strip())
print(name3.strip())
print(name4.strip('H'))

结果为

blob.png


#replace 替换,把老的替换成新的,后面可以接替换的次数

name10 = 'Sam say : hello world!'
print(name10.replace('Sam', 'Tom', 1))

结果为

blob.png


#is系列

name20 = 'Sam123'
print(name20.isalnum())  #判断字符串是否由字母或数字组成
print(name20.isalpha())  #判断字符串是否由字母组成
print(name20.isdigit())  #判断字符串是否由数字组成

结果为

blob.png


# upper,lower

name21 = 'UserName'
print(name21.lower()) #将字符串全部变成小写
print(name21.upper()) #将字符串全部变成大写

结果为:

blob.png


课后习题

#!/usr/bin/env python
# coding: utf-8
__author__ = 'www.py3study.com'
name = "hellO worLd"
# 1:移除 name 变量对应的值两边的空格,并输出处理结果
print(name.strip())

# 2:移除name变量左边的’he’并输出处理结果
print(name.replace("he", ''))
print(name.strip("he"))

# 3:移除name变量右面的'Ld’,并输出处理结果
print(name.replace("Ld", ''))
print(name.strip("Ld"))

# 4:移除name变量开头的'h’与最后的’d’,并输出处理结果
print(name.strip('h').strip('d'))
print(name.replace('h', '').replace('d', ''))

# 5:判断 name 变量是否以 "he" 开头,并输出结果
print(name.startswith('he'))

# 6:判断name变量是否以”Ld”结尾,并输出结果
print(name.endswith('Ld'))

# 7:将 name 变量对应的值中的 所有的“l” 替换为 “p”,并输出结果
print(name.replace('l', 'p'))

# 8:将name变量对应的值中的第一个’l’替换成’p’,并输出结果
print(name.replace('l', 'p', 1))

# 9:将 name 变量对应的值根据 所有的“l” 分割,并输出结果
print(name.split('l'))

# 10:将name变量对应的值根据第一个’l’分割,并输出结果
print(name.split('l', 1))

# 11:将 name 变量对应的值变大写,并输出结果
print(name.upper())

# 12:将 name 变量对应的值变小写,并输出结果
print(name.lower())

# 13:将name变量对应的值首字母’h’大写,并输出结果
print(name.capitalize())

# 14:判断name变量对应的值字母’l’出现几次,并输出结果
print(name.count('l'))

# 15:如何判断name变量对应的值前四位’l’出现几次,并输出结果
print(name.find('l', 0, 3))

# 16:从name变量对应的值中找到’L’对应的索引(如果找不到则报错),并输出结果
print(name.index('L'))

# 17:从name变量对应的值中找到’L’对应的索引(如果找不到则返回-1)输出结果
print(name.find('L'))

# 18:从name变量对应的值中找到’O wo’对应的索引,并输出结果
print(name.find("O wo"))

# 19:请输出 name 变量对应的值的第 2 个字符
print(name[1])

# 20:请输出 name 变量对应的值的前 3 个字符?
print(name[:3])

# 21:请输出 name 变量对应的值的后 2 个字符?
print(name[-2:])

# 22:请输出 name 变量对应的值中 “e” 所在索引位置?
print(name.find('e'))

#获取子序列,去掉最后一个字符。如: oldboy 则获取 oldbo
print(name.split('d'))

# 第二题
li = '123a4b5c'
# 1:通过对li列表的切片形成新的字符串s1,s1 = ‘123’
s1 = li[:3]
print(s1)

# 2:通过对li列表的切片形成新的字符串s2,s2 = ‘a4b’
s2 = li[3:6]
print(s2)

# 3:通过对li列表的切片形成新的字符串s3,s3 = ‘1345’
s3 = li[0] + li[2] + li[4] + li[6]
print(s3)

# 4:通过对li列表的切片形成字符串s4,s4 = ‘2ab’
s4 = li[1] + li[3] + li[-3]
print(s4)

# 5:通过对li列表的切片形成字符串s5,s5 = ‘c’
s5 = li[-1]
print(s5)

# 6:通过对li列表的切片形成字符串s6,s6 = ‘ba2’
s6 = li[-3] + li[3] + li[1]
print(s6)

# 3.使用while和for循环分别打印字符串s=’asdfer’中每个元素
s = 'asdfer'
for i in s:
    print(i)

count2 = 0
while count2 < len(s):
    print(s[count2])
    count2 += 1

# 4.实现一个整数加法计算器(两个数相加):
# 如:content = input(‘请输入内容:’)  # 如用户输入:5+9或5+ 9或5 + 9,然后进行分割再进行计算
#number1 = input("输入一个加法运算:")
content = input("输入加法运算:")
content1 = content.split('+')
sum1 = 0
for i in content1:
    sum1 += int(i.strip())
print('结果为{}'.format(sum1))

# 5.计算用户输入的内容中有几个整数(以个位数为单位)。
# 如:content = input(‘请输入内容:’)   # 如fhdal234slfh98769fjdla
s = 'fhdal234slfh98769fjdla'
sum1 = 0
for i in s:
    if i.isdigit():
        sum1 += 1
    else:
        pass
print(sum1)


阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯