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[-2])   # 注意反向取时第一个值是从-1开始算的,-1,-2,-3,-4.。。。。。。。

# 只能取   字符串是str类型,是不可变类型,只能取不能修改
# 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   注意:这个地方的步长前面要用 : 表示,不像range里面一样使用  ,
# print(res) # hlo

# 反向步长(了解)
# res=msg[6:0:-1]    # 此处的是从第六位位数的5向第一位数的0进行反向取值,因此步长也要是反方向的
# print(res) #" olle"   # 这个反向步长,反向的顾头不顾尾,所以永远取不到第一位数


# msg='hello world'
# res=msg[:] # res=msg[0:11]
# print(res)
#
# res=msg[::-1] # 把字符串倒过来   #   反向切片,-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  下面是关于.format的各种使用方法
'''
https://blog.csdn.net/qq_45726327/article/details/115042863?ops_request_misc
=%257B%2522request%255Fid%2522%253A%2522167676788516782428684627%2522%252C%2
522scm%2522%253A%252220140713.130102334..%2522%257D&request_id=1676767885167824
28684627&biz_id=0&utm_medium=distribute.pc_search_result.none-task-blog-2~all~t
op_positive~default-1-115042863-null-null.142^v73^insert_down2,201^v4^add_ask,
239^v2^insert_chatgpt&utm_term=.format&spm=1018.2226.3001.4187
'''


#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
msg='hello egon hahaha'
# 找到返回起始索引
# print(msg.find('e')) # 返回要查找的字符串在大字符串中的起始索引
# print(msg.find('egon'))
# print(msg.index('e'))
# print(msg.index('egon'))
# 找不到
# print(msg.find('xxx')) # 返回-1,代表找不到
# print(msg.index('xxx')) # 抛出异常,代码不能正常运行

msg='hello egon hahaha egon、 egon'
print(msg.count('egon'))     #   统计次数

#4.3.2、center,ljust,rjust,zfill
# print('egon'.center(50,'*'))
# print('egon'.ljust(50,'*'))    #左填充
# print('egon'.rjust(50,'*'))    #右填充
# print('egon'.zfill(10))        #默认的填充值是0


#4.3.3、expandtabs
# msg='hello\tworld'
# print(msg.expandtabs(2)) # 设置制表符代表的空格数为2

#4.3.4、captalize,swapcase,title
# print("hello world egon".capitalize())   # 首字母大写
# print("Hello WorLd EGon".swapcase())     # 大小写反转
# print("hello world egon".title())      # 每个单词的首字母大写

#4.3.5、is数字系列
#4.3.6、is其他
# print('abc'.islower())
# print('ABC'.isupper())
# print('Hello World'.istitle())
# print('123123aadsf'.isalnum()) # 字符串由字母或数字组成结果为True
# print('ad'.isalpha()) # 字符串由由字母组成结果为True
# print('     '.isspace()) # 字符串由空格组成结果为True
# print('print'.isidentifier())
# print('age_of_egon'.isidentifier())   #  判断你写的名字,关键字是否合法,
# print('1age_of_egon'.isidentifier())   # 关键字有字母数字下划线组成,但是开头不能是数字


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

# isdigit只能识别:num1、num2
# print(num1.isdigit()) # True
# print(num2.isdigit()) # True
# print(num3.isdigit()) # False
# print(num4.isdigit()) # False



# isnumberic可以识别:num2、num3、num4
# print(num2.isnumeric()) # True
# print(num3.isnumeric()) # True
# print(num4.isnumeric()) # True

# isdecimal只能识别:num2
print(num2.isdecimal()) # True
print(num3.isdecimal()) # False
print(num4.isdecimal()) # False





总结:

索引msg='hello world' # print(msg[1])

注意:一定是使用[ ]括号才行 里面的数字代表着索引对应的位置 顾头不顾尾

正向取:第一个字符对应的是数字0     

反向取:最后一个代表的是-1,以此为  -1,-2,-3,-4.。。。。。。

      msg='hello world'                 res=msg[0:5:2] # 0 2 4  步长为2

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

# 默认分隔符是空格

# info='egon 18 male'

# res=info.split()  本身默认以空格为分隔符

# print(res)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值