day8:03 字符串类型

1、作用

掌握字符串的基本操作和处理方法,对于提高编程效率和实现复杂功能具有重要意义。

2、定义

msg=‘hello’ # msg=str(‘msg’)
print(type(msg))

3、类型转换

#str可以把任意其他类型都转成字符串
res=str({‘a’:1})
print(res,type(res))

4、使用:内置方法

4.1 优先掌握

4.1.1、按索引取值(正向取+反向取) :只能取

msg='hello world'
# 正向取
print(msg[0])
print(msg[5])
# 反向取
print(msg[-1])

# 只能取
msg[0]='H'

4.1.2、切片:索引的拓展应用,从一个大字符串中拷贝出一个子字符串

msg='hello world'
# 顾头不顾尾
res=msg[0:5] #x
print(res)
print(msg)

# 步长
res=msg[0:5:2] # 0 2 4
print(res) # hlo

# 反向步长(了解)
res=msg[5:0:-1]
print(res) #" olle"

msg='hello world'
res=msg[:] # res=msg[0:11]
print(res)

res=msg[::-1] # 把字符串倒过来
print(res)

4.1.3、长度len

msg='hello world'
print(len(msg))

4.1.4、成员运算in和not in

# 判断一个子字符串是否存在于一个大字符串中
print("alex" in "alex is sb")
print("alex" not in "alex is sb")
print(not "alex" in "alex is sb") # 不推荐使用

4.1.5、移除字符串左右两侧的符号strip

#默认去掉的空格

msg='      egon      '
res=msg.strip()
print(msg) # 不会改变原值
print(res) # 是产生了新值

#默认去掉的空格

msg='****egon****'
print(msg.strip('*'))

了解:strip只取两边,不去中间

msg='****e*****gon****'
print(msg.strip('*'))

msg='**/*=-**egon**-=()**'
print(msg.strip('*/-=()'))    #移除含有*/-=()的字符集合,没有对应字符时即终止

应用

inp_user=input('your name>>: ').strip() # inp_user=" egon"
inp_pwd=input('your password>>: ').strip()
if inp_user == 'egon' and inp_pwd == '123':
    print('登录成功')
else:
    print('账号密码错误')

4.1.6、切分split:把一个字符串按照某种分隔符进行切分,得到一个列表

# 默认分隔符是空格

info='egon 18 male'
res=info.split()
print(res)

# 指定分隔符

info='egon:18:male'
res=info.split(':')
print(res)

指定分隔次数(了解)

info='egon:18:male'
res=info.split(':',1)
print(res)

4.1.7、循环

info='egon:18:male'
for x in info:
    print(x)

4.2 需要掌握

4.2.1、strip,lstrip,rstrip

msg='***egon****'
print(msg.strip('*'))
print(msg.lstrip('*'))
print(msg.rstrip('*'))

4.2.2、lower,upper

msg='AbbbCCCC'
print(msg.lower())
print(msg.upper())

4.2.3、startswith,endswith

print("alex is sb".startswith("alex"))
print("alex is sb".endswith('sb'))

4.2.4、format

4.2.5、split,rsplit:将字符串切成列表

info="egon:18:male"
print(info.split(':',1)) # ["egon","18:male"]
print(info.rsplit(':',1)) # ["egon:18","male"]

4.2.6、join: 把列表拼接成字符串

l=['egon', '18', 'male']
res=l[0]+":"+l[1]+":"+l[2]
res=":".join(l) # 按照某个分隔符号,把元素全为字符串的列表拼接成一个大字符串
print(res)
l=[1,"2",'aaa']
":".join(l)

4.2.7、replace

msg="you can you up no can no bb"
print(msg.replace("you","YOU",))
print(msg.replace("you","YOU",1))

4.2.8、isdigit

#判断字符串是否由纯数字组成
print('123'.isdigit())
print('12.3'.isdigit())

age=input('请输入你的年龄:').strip()
if age.isdigit():
    age=int(age) # int("abbab")
    if age > 18:
        print('猜大了')
    elif age < 18:
        print('猜小了')
    else:
        print('才最了')
else:
    print('必须输入数字,傻子')

4.3了解

4.3.1、find,rfind,index,rindex,count

find() :用于查找子字符串(在这种情况下是 ‘e’)在字符串中首次出现的位置(索引)
rfind() :但它返回的是子字符串最后一次出现的位置(索引)
index() :与 find() 方法类似,但它在找不到子字符串时会抛出一个 ValueError 异常,而不是返回 -1
rindex() :与 index() 方法类似,但它是返回子字符串最后一次出现的位置(索引)

msg='hello egon hahaha'
# 找到返回起始索引
print(msg.find('e')) # 返回要查找的字符串在大字符串中的起始索引
print(msg.rfind('h'))
print(msg.index('e'))
print(msg.rindex('e'))

>>运行结果:
1
15
1
6

# 找不到
print(msg.find('xxx')) # 返回-1,代表找不到
print(msg.index('xxx')) # 抛出异常

>>运行结果:
#-1
#Traceback (most recent call last):
#  File "/home/xionglinhui/my_python_project/temp.py", line 17, in <module>
#    print(msg.index('xxx')) # 抛出异常
#ValueError: substring not found


msg='hello egon hahaha egon、 egon'
print(msg.count('egon'))

>>运行结果:3

4.3.2、center,ljust,rjust,zfill

print('egon'.center(50,'*'))
print('egon'.ljust(50,'*'))
print('egon'.rjust(50,'*'))
print('egon'.zfill(10))

>>运行结果:
***********************egon***********************
egon**********************************************
**********************************************egon
000000egon

4.3.3、expandtabs

msg=‘hello\tworld’

print(msg.expandtabs(2)) # 设置制表符代表的空格数为2

4.3.4、captalize,swapcase,title

# capitalize() 方法将字符串的第一个字符转换为大写,其余字符转换为小写  
print("hello world egon".capitalize())  # 输出: "Hello world egon"  
  
# swapcase() 方法将字符串中的大写字母转换为小写,小写字母转换为大写  
print("Hello WorLd EGon".swapcase())  # 输出: "hELLO wORLD eGON"  
  
# title() 方法将字符串中的每个单词的首字母转换为大写,其余字母转换为小写  
print("hello world egon".title())  # 输出: "Hello World Egon"

4.3.5、is数字系列

```python
print('ABC'.isupper())  # 检查字符串是否全部由大写字母组成  
# 输出: True,因为'ABC'全部由大写字母组成  
  
print('Hello World'.istitle())  # 检查字符串是否是一个标题化字符串(即每个单词的首字母大写)  
# 输出: True,因为'Hello World'的每个单词的首字母都是大写  
  
print('123123aadsf'.isalnum())  # 检查字符串是否全部由字母或数字组成  
# 输出: True,因为'123123aadsf'全部由字母和数字组成  
  
print('ad'.isalpha())  # 检查字符串是否全部由字母组成  
# 输出: True,因为'ad'全部由字母组成  
  
print('     '.isspace())  # 检查字符串是否全部由空白字符(空格、制表符、换行符等)组成  
# 输出: True,因为'     '全部由空格组成  
  
print('print'.isidentifier())  # 检查字符串是否是一个有效的Python标识符  
# 输出: True,因为'print'是一个有效的Python标识符(尽管它也是一个内置函数名)  
  
print('age_of_egon'.isidentifier())  # 检查字符串是否是一个有效的Python标识符  
# 输出: True,因为'age_of_egon'是一个有效的Python标识符  
  
print('1age_of_egon'.isidentifier())  # 检查字符串是否是一个有效的Python标识符  
# 输出: False,因为Python标识符不能以数字开头

4.3.7 isdigit、isnumberic、isdecimal对比

案例:
num1=b’4’ #bytes
num2=u’4’ #unicode,python3中无需加u就是unicode
num3=‘四’ #中文数字
num4=‘Ⅳ’ #罗马数字

①isdigit():检查字符串中的所有字符是否都是数字(0-9)

对于bytes对象(如num1),它只检查ASCII范围内的字符。因为’4’的ASCII值是数字字符,所以num1.isdigit()返回True。

isdigit只能识别:num1、num2

print(num1.isdigit()) # True
print(num2.isdigit()) # True
print(num3.isdigit()) # False
print(num4.isdigit()) # False

②isnumeric():检查字符串中的所有字符是否都是数字字符,包括Unicode数字字符(如中文数字、罗马数字等)。
num2(‘4’)是数字字符,所以num2.isnumeric()返回True。
num3(中文数字“四”)和num4(罗马数字“Ⅳ”)都被视为数字字符(尽管它们不是标准的0-9数字),所以它们的isnumeric()方法都返回True。

print(num2.isnumeric()) # True
print(num3.isnumeric()) # True
print(num4.isnumeric()) # True

③isdecimal():类似于isdigit(),但它更严格地检查字符串是否只包含十进制数字字符(0-9)

print(num2.isdecimal()) # True
print(num3.isdecimal()) # False
print(num4.isdecimal()) # False
  • 17
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值