黑马程序员学习笔记
一.认识字符串
字符串是Python中常用的数据类型。我们一般使用引号来创建字符串。创建字符串很简单,只要为变量分配一个值即可。
a = 'hello world'
b ="abcdefg"
print(type(a))
print(type(b))
1.1字符串特征
- 一对引号字符串
name1 = 'tom'
name2 = "rose"
- 三引号字符串
name3 = '''Tom'''
name4 = '''rose'''
a ='''i am Tom,nice to meet you!'''
b = "''" i am rose,nice to meet you!"""
注意:三引号形式的字符串支持换行。
1.2字符串输出
print('hello world')
name = 'Tom'
print('我的名字是%s' % name)
print(f'我的名字是{name}')
字符串输入
在python中,使用input()接收用户输入
- 代码
name =input('请输入您的名字:')
print(f'您输入的名字是{name}')
print(type(name))
二.下标
“下标又叫“索引””,就是编号。比如火车座位号,座位号,座位号的作用:按照编号快速查找到对应的座位。同理,下标的作用是通过下标快速找到对应的数据。
name = "abcdef"
print(name[0])
三.切片
切片是指对操作的对象截取其中一部分的操作。字符串,列表,元组都支持切片操作。
3.1语法
序列【开始位置下标:结束位置下标:步长】
1.不包含结束位置下标对应的数据,正负整数均可
2.步长是选取时间间隔,正整数均可,默认步长为1
3.如果选取方向步长方向相反则不能打印
3.2体验
name ="abcdefg"
print (name[2:5:1]) #cde
print(name[2:5]) #cde
print(name【:5】) #abcde
四.常用操作方法
字符串的常用操作方法有查找,修改和判断三大类。
4.1查找
所谓字符串查找方法即是查找子串在字符串中的位或出现的次数。
- find():检测某个子串是否包含在这个字符串中,如果在返回这个字符串开始的位置下标,否则则返回-1。
- 语法
- 字符串序列.find(子串,开始位置下标,结束位置下标)
注意:开始和结束位置下标可以省略,表示在整个字符串序列中查找。
2.快速体验
mystr = ''hello word and itcast and itheima and python"
print(mystr.find('and')) #12
print(mystr.find('and',15,30)) #23
print(mystr.find('ands')) # -1
- index():检测某个子串是否包含在这个字符串中,如果在返回这个子串开始的位置下标,否则则报异常。
- count()统计出现次数#右侧开始查找
- rindex() #右侧开始查找
#find
#index
#count
#rfind
#rindex
mystr = "hello world and itcast and itheima and Python"
#print(mystr.find('and'))
#print(mystr.find('ands'))
#print(mystr.find('and',15,30))
#print(mystr.index('and'))
# print(mystr.index('ands'))
# print(mystr.index('and',15,30))
#print(mystr.count('and'))
# print(mystr.counr('ands'))
#print(mystr.count('ands',15,30))
#print(mystr.rfind('and'))
#print(mystr.rfind('ands'))
print(mystr.rindex('and',15,30))
4.2修改
所谓修改字符串,指的就是通过函数的形式修改字符串中的数据。
-replace():替换
1.语法
字符串序列.replace(旧子串,新子串,替换次数)
注意:替换次数如果查出子串出现次数,则替换次数为该子串出现次数。
2.快速体验
mystr = "hello word and itcast and itheima and Python"
# new_str = mystr.replace('and','he')
# print(mystr)
# print(new_str)
# -- 说明 字符串是不可变类型
# new_str = mystr.replace('and','he',1)
# print(new_str)
- split():按照指定字符分割字符串
1.语法
字符串序列.split(分割字符,num)
注意:num表示的是分割字符出现的次数,即将来返回数据个数为num+1个
2.快速体验
mystr = "hello word and itcast and itheima and Python"
new_str = mystr.replace('and','he',1)
print(new_str)
- 注意:如果分割字符串是原有字符串,分割后则丢失该字串。
join(): 用一个字符或子串合并字符串,即是将多个字符串合并为一个字符串。
1.语法
字符或字串.join(多字符串组成的序列)
2.快速体验
#合并字符为一个大字符串
mylist = ['aa','bb','cc']
new_str = "...".join(mylist)
print(new_str)
大小写转换
- capitalize(): 将字符串第一个字符转换成大写
mystr = "hello world and itcast and itheima and Python"
print(mystr.capitalize())
注意:capitalize()函数转换后,只字符串第一个字符大写,其他的字符全部小写。
- title():将字符串每个单词首字母转换成大写。
- lower():将字符串中大写转小写。
- upper():将字符串中小写转大写。
- lstrip(): 删除字符串左侧空白字符。
mystr = 'hello world i am Python'
# new_str = mystr.capitalize()
# new_str = mystr.title()
# new_str =mystr.upper()
new_str = mystr.lower()
print(new_str)
删除空白字符
- lstrip(): 删除字符串左侧空白字符。
- rstrip():删除字符串右侧空白字符。
- strip():删除字符串两侧空白字符。
mystr = 'hello world i am Python'
print(mystr)
# new_str = mystr.strip()
#new_str = mystr.rstrip()
# print(new_str)
new_str =mystr.strip()
print(new_str)
左中右对齐
- ljust(): 返回一个原字符串左对齐,并使用指定字符(默认空格)
- 语法 字符串序列.ljust(长度,填充字符)
- rjust():返回一个原字符串右对齐,并使用指定字符(默认空格)填充至对应长度的新字符串,语法和ljust()相同。
- center():居中对齐
4.3判断
所谓判断即是判断真假,返回的结果是布尔型数据类型:True或False.
-startswith(): 检查字符串是否是以指定字串开头,是则返回True,否则返回False。如果设置开始和结束位置下标,则在指定范围检查。
1.语法
字符串序列.startswith(子串,开始位置下标,结束位置下标)
2.快速体验
mystr = ''hello world and itcast and itheima and python "
结果:True
print(mystar.startswith('hello'))
结果:False
- endswith(): 检查字符串是否是指定子串结尾,是则返回true,否则返回false。如果设置开始和结束位置下标,则在指定范围内检查。
- isalpha(): 如果字符串至少有一个字符并且所有字符都是字母则返回True,否则返回false。
- isdigit(): 如果字符串只包含数字则返回True否则返回False
- isalnum(): 如果字符串至少有一个字符并且所有字符都是字母或数字则返回true,否则返回false。