数据类型-字符串(str)
文章目录
1.字符串的定义方法
- 单引号:a = ‘nigar’
- 双引号:b = “lee”
- 当字符串内有单引号时,单引号+转义字符:c = ‘what’s’
- 当字符串内有单引号时,双引号:d = “westos’s”
三引号(多行输出):
e= """
用户管理系统
1.添加用户
2.删除用户
3.显示用户
.....
"""
2.字符串的特性
- 索引
索引:0 1 2 3 4 索引从0开始
s = 'hello'
print(s[0]) ##显示第一个字符
print(s[1]) ##第二个字符
print(s[4]) ##拿出最后一个字符
print(s[-1]) ##拿出最后一个字符
结果:
- 切片
s = 'hello'
print(s[0:3]) ##显示索引为0 1 2的字符
print(s[0:4:2]) ##s[start:stop:step] 从satrt开始到end -1结束 步长为step
print(s[:]) ##显示所有的字符
print(s[:3]) ##显示前3个字符
print(s[::-1]) ##字符串的反转
print(s[2:]) ##除了前2个字符之外的其他字符
结果:
- 重复
==print(s * 10)==将字符串s打印10遍
s = 'hello'
print(s * 10)
结果:
- 连接
print(‘hello’ + ‘world’) 将两个字符串连接起来形成新的字符串并打印
s = 'hello'
print('hello ' + 'world')
结果:
- 成员操作符
‘he’ in s:如果字符串s中有he元素,就返回True
‘aa’ in s:如果字符串s中有aa元素,就返回False
‘he’ not in s:如果字符串s中有he元素,就返回False
s = 'hello'
print('he' in s)
print('aa' in s)
print('he' not in s)
结果:
- for循环遍历
s = 'hello'
for i in s:
print(i)
结果:
- 枚举
返回索引值与对应的value值
for i,v in enumerate('hello'):
print(str(i) + '---' + v)
结果:
- zip压缩
s1 = 'gulinigar'
s2 = '257483495'
for i in zip(s1,s2):
print(i)
结果:
3.字符串的常用方法
- 字符串的判断
s.istitle() 是否为标题,返回布尔值,只要有一个元素不满足,就返回False
s.isupper() 是否为大写字母,返回布尔值,只要有一个元素不满足,就返回False
s.islower() 是否为小写字母,返回布尔值,只要有一个元素不满足,就返回False
s.isdigit() 是否为数字,返回布尔值,只要有一个元素不满足,就返回False
s.isalpha() 是否为字母,返回布尔值,只要有一个元素不满足,就返回False
s.isalnum() 是否为字母与数字的结合,返回布尔值,只要有一个元素不满足,就返回False
s.startswith(xxx) 以xxx开始
s.endswith(xxx) 以xxx结尾
print('hello'.isupper()) #是否为大写字母,返回布尔值,只要有一个元素不满足,就返回False
print('Hello'.isupper())
print('HELLO'.isupper())
print('hello'.islower()) #是否为小写字母,返回布尔值,只要有一个元素不满足,就返回False
print('Hello'.islower())
print('sheena1109'.isdigit()) #是否为数字,返回布尔值,只要有一个元素不满足,就返回False
print('jay0118'.isalpha()) #是否为字母,返回布尔值,只要有一个元素不满足,就返回False
print('sehun0412'.isalnum()) #是否为字母与数字的结合,返回布尔值,只要有一个元素不满足,就返回False
示例1:
filename = 'hello.loggggg'
if filename.endswith('.log'):
print(filename)
else:
print('error.file')
结果:
示例2:
url = 'https://172.25.254.250/index.html'
if url.startswith('http://'):
print('爬取网页')
else:
print('不能爬取')
结果:
- 字符串的转换
s.lower() :转化为小写字母
s.upper() :转化为大写字母
s.title() :转化为标题
print('Hello'.lower()) # s.lower() 转化为小写字母
print('hello'.upper()) # s.upper() 转化为大写字母
print('hello'.title()) # s.title() 转化为标题
结果:
- 字符串的去除
s.rstrip() :去除右边的空格
s.lstrip() :去除左边的空格
s.strip() :去除空格
注意:s.strip()去除左右两边的空格,空格为广义的空格(包括:\t \n)
s.strip(‘x’) :去除字符串中的所有字符x
s.lstrip(‘x’) :去除字符串中最左边的字符x
s = ' hello '
print(s.rstrip()) # s.rstrip() 去除右边的空格
print(s.lstrip()) # s.lstrip() 去除左边的空格
print(s.strip()) # s.strip() 去除空格
s2 = '\thello\n'
print(s2)
print(s2.strip()) # s.strip() 去除左右两边的空格,空格为广义的空格 包括:\t \n
s3 = 'helloh'
print(s3.strip('h')) # s.strip('x') 去除字符串中的所有字符x
print(s3.lstrip('h')) # s.lstrip('x') 去除字符串中最左边的字符x
结果:
- 字符串的对齐
s.center(num) :字符串s位于30个单元格的中间
s.center(num,’#’) :字符串s位于30个单元格的中间,其他单元格用#补齐
s.ljust(num,’#’) :字符串s位于30个单元格的左边,其他单元格用#补齐
s.rjust(num,’#’) :字符串s位于30个单元格的右边,其他单元格用#补齐
print('学生管理系统'.center(30))
print('学生管理系统'.center(30,'*'))
print('学生管理系统'.ljust(30,'*'))
print('学生管理系统'.rjust(30,'*'))
结果:
- 字符串的查找与替换
s.find(‘xxx’) :找到子字符串xxx,并返回子字符串最小的索引
s.rfind(‘xxx’) :找到字符串s最右边出现的子字符串xxx,并返回子字符串最小的索引
s.replace(‘xxx’,‘xxx’) :替换字符串中的xxx为xxx
s = 'hello world hello'
# find找到子字符串,并返回最小的索引
print(s.find('hello'))
print(s.find('world'))
print(s.rfind('hello'))
# 替换字符串中的hello为westos
print(s.replace('hello','westos'))
结果:
- 字符串的统计
s.count(‘xxx’) :统计字符串s中子字符串xxx出现的次数
len(s) :统计字符串s的长度
# s.count('xxx'):统计字符串s中子字符串xxx出现的次数
print('hello'.count('l'))
print('hello'.count('ll'))
# len(s):统计字符串s的长度
print(len('westossssss'))
结果:
- 字符串的分离和连接
s.split(‘xxx’) :以xxx作为分隔符分离字符串s,存放在列表中
‘xxx’.join(s) :通过指定的连接符号,连接列表中的每个字符,形成新的字符串
# 分离
s = '172.25.254.250'
s1 = s.split('.') #s.split('.'):以.作为分隔符分离字符串s,存放在列表s1中
print(s1)
print(s1[::-1]) #倒序
date = '2019-12-18'
date1 = date.split('-') #s.split('-'):以.作为分隔符分离字符串data,存放在列表date1中
print(date1)
# 连接:'xxx'.join(s) 通过指定的连接符号,连接每个字符
print(''.join(date1)) #''.join(date1):直接连接每个字符
print('/'.join(date1)) #'/'.join(date1):通过指定的连接符号/,连接每个字符
print('~~'.join('hello'))
结果: