2021-06-30 Python基础知识Day03

字符串切片slice操作

标准格式为: [起始偏移量 start:终止偏移量 end:步长 step]

三个量为正数的情况:
  • [:] 提取整个字符串
>>>“abcdef”[:]
“abcdef”
  • [start:]从start索引开始到结尾
“abcdef”[2:]
“cdef”
  • [:end]从头开始知道 end-1
“abcdef”[:2]
“ab”
  • [start:end]从 start 到 end-1
“abcdef”[2:4]
“cd”
  • [start🔚step]从 start 提取到 end-1,步长是 step
“abcdef”[1:5:2]
“bd”
三个量为负数:
  • 倒数三个
>>>"abcdefghijklmnopqrstuv wxyz"[-3:]
“xyz”
  • 倒数第八个到倒数第三个(包头不包尾)
>>>"abcdefghijklmnopqrstuv wxyz"[-8:-3]
'stuvw'
  • 步长为负,从右到左 反向提取
>>>"abcdefghijklmnopqrstuv wxyz"[::-1]
'zyxwvutsrqpon mlkjihgfedcba'
split()分割、join()合并
  • split() 指定分隔符将字符串分割成多个子字符串
    默认空白字符。
>>> a = "to be or not to be"
>>> a.split()
['to', 'be', 'or', 'not', 'to', 'be']
>>> a.split('be')
['to ', ' or not to ', '']
  • join()则是用字符将一系列字符串连接起来
>>> a = ['sxt','sxt100','sxt200']
>>> '*'.join(a)
'sxt*sxt100*sxt200'

字符串拼接符+,在每次拼接都会创建新的对象,因此不推荐使用+来拼接字符串
推荐使用join()函数,仅需要新建一次对象,因此效率更高

import time
t1=time.time()
a=""
for i in range(100000):
	a += "python"
t2=time.time()
print("+耗时:", t2-t1)

t3=time.time()
li=[]
for i in range(100000):
	li.append("python")

b="".join(li)
t4=time.time()
print("join()耗时:", t4-t3)
#输出:
+耗时: 0.01675891876220703
join()耗时: 0.0059452056884765625
字符串驻留机制

Python 支持字符串驻留机制,对于符合标识符规则的字符串(仅包含下划线(_)、字母 和数字)会启用字符串驻留机制驻留机制。

>>> a = "abd_33"
>>> b = "abd_33"
>>> a is b
True
>>> c = "dd#"
>>> d = "dd#"
>>> c is d
False
>>> str1 = "aa"
>>> str2 = "bb"
>>> str1+str2
is "aabb"
False
>>> str1+str2 == "aabb"
True
成员操作符号

in / not in 关键字,判断某个字符(串)是否在字符串中

>>> a="hello"
>>> "ll" in a
True
常用查找方法

我们以一段文本作为测试:
a=’’‘我是高淇,今年 18 岁了,我在北京尚学堂科技上班。我的儿子叫高洛希,他 6 岁了。我 是一个编程教育的普及者,希望影响 6000 万学习编程的中国人。我儿子现在也开始学习编 程,希望他 18 岁的时候可以超过我’’’
在这里插入图片描述在这里插入图片描述

去除字符串首尾信息

strip()函数去除字符串首尾指定信息,lstrip()和rstrip()分别为去除左、右指定信息。

>>> "*s*x*t*".strip("*")
's*x*t'
>>> "*s*x*t*".lstrip("*")
's*x*t*'
>>> "*s*x*t*".rstrip("*")
'*s*x*t'
大小写转换

a = “gaoqi love programming, love SXT”

a.capitalize() #产生新的字符串,首字母 大写
‘Gaoqi love programming, love sxt’

a.title() #产生新的字符串,每个单 词都首字母大写
‘Gaoqi Love Programming, Love Sxt’

a.upper() #产生新的字符串,所有字 符全转成大写
‘GAOQI LOVE PROGRAMMING, LOVE SXT’

a.lower() #产生新的字符串,所有字 符全转成小写
‘gaoqi love programming, love sxt’

a.swapcase() #产生新的,所有字母大小 写转换
‘GAOQI LOVE PROGRAMMING, LOVE sxt’

其他
  1. isalnum() 是否为字母或数字
  2. isalpha() 检测字符串是否只由字母组成(含汉字)。 3. isdigit() 检测字符串是否只由数字组成。
  3. isspace() 检测是否为空白符
  4. isupper() 是否为大写字母
  5. islower() 是否为小写字母
format()格式化字符串

str.format(),通过{}和: 代替之前的%

>>> a = "名字是:{0},年龄是:{1}" 
>>> a.format("高淇",18) 
'名字是:高淇,年龄是:18'
>>> a.format("高希希",6) 
'名字是:高希希,年龄是:6'
>>> b = "名字是:{0},年龄是{1}。{0}是个好小伙" 
>>> b.format("高淇",18)
'名字是:高淇,年龄是 18。高淇是个好小伙'
>>> c = "名字是{name},年龄是{age}"
>>> c.format(age=19,name='高淇') 
'名字是高淇,年龄是 19'
填充与对齐

格式{:$>6} :后面紧跟填充的字符,最后是宽度

  • ^ :居中
  • < :左对齐
  • > :右对齐
>>> "{:*>8}".format("245")
'*****245'
>>> "我是{0},我喜欢数字{1:*^8}".format("高淇","666")
'我是高淇,我喜欢数字**666***'
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值