【python学习】字符串详解,面试必问公司的问题

简介: 【python学习】字符串详解,面试必问公司的问题

1.转义字符

对于单引号或者双引号这些特殊的符号,我们可以对他们进行转义。例如,对字符串中的单引号进行转义:

print('Ok sir, let’s go! ')

注意:print函数自身带了一个换行,如果使用print()就可以输出一个换行

2.输入输出


#字符串的格式化输出
name1 =“小明”
name2=“小红”
print(“大家好,我叫%s”%name1)
print(“大家好,我们是%s和%s”%(name1,name2))
#字符串的输入
#username=input(“请输入用户名”)
#print(username)
#字符串的存储方式

贴士:字符串中的每个字符都对应一个下标,下标编号是从0开始的

3.切片


切片操作基本表达式:

object[start_index:end_index:step]

含义:object[起始:结束:步长]

切片选取的区间属于左闭右开型,即从"起始"位开始,到"结束"位的前一位结束(不包含结束位本身)

Python可切片对象的索引方式

包括:正索引和负索引两部分.

如下图所示,以list对象a = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]为例:

参数解释:

object[起始:结束:步长]

  • step:正负数均可,其绝对值大小决定了切取数据时的‘‘步长”,而正负号决定了“切取方向”,正表示“从左往右”取值,负表示“从右往左”取值。当step省略时,默认为1,即从左往右以步长1取值。“切取方向非常重要!”“切取方向非常重要!”“切取方向非常重要!”,重要的事情说三遍!
  • start_index:表示起始索引(包含该索引对应值);该参数省略时,表示从对象“端点”开始取值,至于是从“起点”还是从“终点”开始,则由step参数的正负决定,step为正从“起点”开始,为负从“终点”开始。
  • end_index:表示终止索引(不包含该索引对应值);该参数省略时,表示一直取到数据“端点”,至于是到“起点”还是到“终点”,同样由step参数的正负决定,step为正时直到“终点”,为负时直到“起点”。

4.字符串内建函数


1.find函数:检测字符串是否包括子字符串

格式:str.find(str, beg=0, end=len(string))

参数如下:

str – 指定检索的字符串。

beg – 开始索引,默认为0。

end – 结束索引,默认为字符串的长度。

找到则返回索引位置,找不到返回-1。

#eg:
s1=“svsvhsjf”
result=s1.find(“m”,0,len(s1))
print(result)

-1

2.index函数:检测字符串是否包括子字符串

格式:str.index(str, beg=0, end=len(string))

参数如下:

str – 指定检索的字符串。

beg – 开始索引,默认为0。(包括)

end – 结束索引,默认为字符串的长度。(不包括)

找到则返回索引位置,找不到抛出异常。

#eg:
s2=“svsvhsjf”
result=s2.index(“f”,0,len(s2))
print(result)

7

3.count函数:统计字符串中某个字符、字符串的个数

格式:str.count(sub, start= 0, end=len(string))

参数如下:

sub – 搜索的子字符串

start – 字符串开始搜索的位置(包括)

end – 字符串中结束搜索的位置(不包括)

#eg:
s3=“svsvhsjf”
result=s3.count(“s”,0,len(s3))
print(result)
3
s4=“svsvhsjfsviihsvr”
result=s4.count(“sv”,0,len(s4))#在s中找"sv"的次数
print(result)

4

4.replace函数:将旧字符串替换为新字符串

格式:str.replace(old, new[, max])

参数如下:

old需要进行更换的旧子串

new新的子串,将取代旧的子字符串(子串可以为空)

max如果可选参数max值给出,表示出现前max的次数的子串被替换

#eg:
str=“monkey likes lion,wow!!!monkey likes lion very much!!”
print(str.replace(“li”,“ha”))
print(str.replace(“li”,“ha”,3))
print(str.replace(‘li’,‘’))
print(str)

输出结果

注意:运行结果来看,replace函数不会改变原始字符串的值,如果需要使用替换后的字符串,需要将其重新赋值给一个新的变量

5.splite函数:通过指定分隔符对字符串进行切片

格式:str.split(str="", num=string.count(str))

参数如下:

str – 分隔符。默认为所有空字符,如空格,tab等。

num – 分割次(默认:有多少个str分割多少次)

eg:
string = “www.gziscas.com.cn”
1.以’.'为分隔符
print(string.split(’.’))
[‘www’, ‘gziscas’, ‘com’, ‘cn’]
2.分割两次
print(string.split(’.’,2))
[‘www’, ‘gziscas’, ‘com.cn’]
3.分割两次,并取序列为1的项
print(string.split(’.’,2)[1])
gziscas
4.分割两次,并把分割后的三个部分保存到三个文件
u1, u2, u3 =string.split(’.’,2)
print(u1)—— www
print(u2)—— gziscas
print(u3) ——com.cn
6.capitalize:第一个字符大写,其他字符小写
#格式:
str.capitalize()
#eg:
s5=“this is hello”
print(s5.capitalize())

7.title:所有单词首字母大写,其余字母小写
#格式:
str.title()
#eg:
s6=“this is hello”
print(s6.title())


相关文章
|
4天前
|
算法框架/工具 索引 Python
Python基础教程(第3版)中文版 第三章 使用字符串(笔记)
Python基础教程(第3版)中文版 第三章 使用字符串(笔记)
|
5天前
|
Python
使用Python处理字符串。
使用Python处理字符串。
|
17小时前
|
Python
GitHub爆赞!终于有大佬把《Python学习手册》学习笔记分享出来了
这份笔记的目标是为了给出一份比较精炼,但是又要浅显易懂的Python教程。《Python学习手册》中文第四版虽然比较简单,但是措辞比较罗嗦,而且一个语法点往往散落在多个章节,不方便读者总结。 我在做笔记时,将一个知识点的内容都统筹在一个章节里面,因此提炼性大大提高。而且还有《Python学习手册》中文第四版的翻译在某些章节(可能难度较大?)措辞可能前后矛盾。当知识点提炼之后就能够很快的找到一些难以理解的概念的上下文,方便吃透这些难点。
GitHub爆赞!终于有大佬把《Python学习手册》学习笔记分享出来了
这份笔记的目标是为了给出一份比较精炼,但是又要浅显易懂的Python教程。《Python学习手册》中文第四版虽然比较简单,但是措辞比较罗嗦,而且一个语法点往往散落在多个章节,不方便读者总结。 我在做笔记时,将一个知识点的内容都统筹在一个章节里面,因此提炼性大大提高。而且还有《Python学习手册》中文第四版的翻译在某些章节(可能难度较大?)措辞可能前后矛盾。当知识点提炼之后就能够很快的找到一些难以理解的概念的上下文,方便吃透这些难点。
|
3天前
|
Python 索引
【Python字符串攻略】:玩转文字,编织程序的叙事艺术
【Python字符串攻略】:玩转文字,编织程序的叙事艺术
|
3天前
|
Python
刷题——Python篇(3)字符串
刷题——Python篇(3)字符串
|
3天前
|
索引 Python
Python零基础入门-2 数字、字符串和列表
Python零基础入门-2 数字、字符串和列表
|
5天前
|
Python
Python使用正则表达式分割字符串
在Python中,你可以使用re模块的split()函数来根据正则表达式分割字符串。这个函数的工作原理类似于Python内置的str.split()方法,但它允许你使用正则表达式作为分隔符。
|
8天前
|
存储 算法 数据挖掘
深入解析力扣166题:分数到小数(模拟长除法与字符串操作详解及模拟面试问答)
深入解析力扣166题:分数到小数(模拟长除法与字符串操作详解及模拟面试问答)
|
8天前
|
存储 算法 数据挖掘
LeetCode 题目 43:字符串相乘 多种算法分析对比 【python】
LeetCode 题目 43:字符串相乘 多种算法分析对比 【python】