python初学入门——————字符串


前言

字符串是python常用的变量类型,其包括了很多函数方法。本文重点介绍这些方法的使用。

一、认识字符串

在之前的文章提到过,字符串是用单引号或者双引号进行声明。

nam = '张三'
name = "张三"

初次之外也可以使用三引号

name3 = ''' Tom '''
name4 = """ Rose """
a = ''' i am Tom,
 nice to meet you! '''
b = """ i am Rose,
 nice to meet you! """

三引号支持换行

二、字符串的使用

1.输出

在前篇文章具体提到过输入输出,读者可以翻阅之前文章。

2. 认识下标

下标也可以理解为索引。用来标识位置,下标的作⽤即是通过下标快速找到对应的数据。
在这里插入图片描述

正数小标从第一个字母开始,并且以0为起始。负数下标从末尾第一个字母开始,以-1起始。
使用

变量名[下标]

就可以获取特定索引位置的字母。
如:

name="hello,python"
print(name[0])    #结果;z
print(name[-12])   #结果;z

当下标数字超过字符长度时,程序将会报错 :IndexError: string index out of range
利用len()方法可以直接获取字符长度

name="hello,python"
print(len(name))
#结果为:12

三、切片

1. 切片的定义

切⽚是指对操作的对象截取其中⼀部分的操作。字符串、列表、元组都⽀持切⽚操作。
(列表和元组在后面进行详细介绍)

2. 切片的使用

切片语法: 序列[开始位置下标:结束位置下标:步⻓]
需要注意:

  1. 不包含结束位置下标对应的数据, 正负整数均可;
  2. 步⻓是选取间隔,正负整数均可,默认步⻓为1。

以下面代码为例:

name="hello,python"
print(name[1:3:1])
可以这样理解:
从下标为1(字母e)开始截取,截取到下标3(字母l),但不包括下标3的值,每次步长为1.
#所以结果为:
el

接下来对各种情况进行测试:

正数下标时:

name="hello,python"
# 正常截取
print(name[1:3:1])
print(name[1:15:]) #结束下标超出也只能截取全部字符串
# 在非默认值以前的下标数字可以省略,非默认值以后的冒号和数字都可以省略
# 当不写步长时,会取默认值1
print(name[1:3])
# 不写起始下标,默认值为0
print(name[:3:1])
# 不写结束下标
print(name[1::2])
print(name[1::])  # 省略非默认值以后的数字
print(name[1:])  # 省略非默认值以后的冒号和数字,注意1后面的冒号不可以省略
# 不写起始和步长
print(name[:3:])
print(name[:4])
# 只写步长
print(name[::2])  #在非默认值以前的下标数字可以省略,冒号不可以

负数下标时:

name="hello,python"
print(name[5:3:-1])   # 结果为:,o
print(name[::-1])   # 结果为:nohtyp,olleh  这样就可以让字符串进行倒序
print(name[-4:-1:])  # 结果为:tho

注意:
起始下标的默认值为0.,结束下标默认值为字符串长度,步长默认值为1
当步长为正数时候,起始位置的下标数字必须小于结束下标的数字。
当步长为负数时候,起始位置的下标数字必须大于于结束下标的数字。

四、字符串常用方法

1. 查找

(1)find()查找这个字段是否存在这个字符串中。如果存在则返回第一个符合条件字段开始的下标,不存在则返回-1.

语法:变量名.find(“要查找的字段”,开始位置的下标,结束位置的下标)

例如:

name="hello,python"
find=name.find("llo",1,8)
print(find)
#输出结果为:
2

(2)index()检测某个⼦串是否包含在这个字符串中,如果在返回这个⼦串开始的位置下标,否则报异常。

注意find()和index()区别。find失败会返回-1,而index()会直接报错。

语法:变量名.index(“要查找的字段”,开始位置的下标,结束位置的下标).
(和find()使用一样)

rfind(): 和find()功能相同,但查找⽅向为右侧开始。
rindex():和index()功能相同,但查找⽅向为右侧开始。
count():返回某个⼦串在字符串中出现的次数

2. 修改

修改主要是对字符串内容进行修改,例如:替换某个字符、删除、合并等操作。
由于牵扯的方法很多,作者重点介绍下几个常用方法。
replace():替换方法

语法:变量.replace(原来字符串,新字符串,替换次数)

name="hello,hello,hello,hello,hello"
replace1=name.replace("hello", "python")
replace2=name.replace("hello", "python",2)
print(replace1)   #输出结果为:python,python,python,python,python
print(replace2)   #输出结果为:python,python,hello,hello,hello

替换不会改变原来字符串的内容

split()会将字符串的某个单词进行切除。

语法:变量.split(分割字符,次数)

name="hello world and itcast and itheima and Python"
split1=name.split("and")
split2=name.split("and",2)
print(split1)  #结果为:['hello world ', ' itcast ', ' itheima ', ' Python']
print(split2)  #结果为:['hello world ', ' itcast ', ' itheima and Python']
print(name)   #结果为:hello world and itcast and itheima and Python

join():⽤⼀个字符或⼦串合并字符串,即是将多个字符串合并为⼀个新的字符串。

语法:变量.join(多字符串组成的序列)

list1 = ['chuan', 'zhi', 'bo', 'ke']
t1 = ('aa', 'b', 'cc', 'ddd')
print('_'.join(list1)) # 结果:chuan_zhi_bo_ke
print('...'.join(t1))  # 结果:aa...b...cc...ddd

其他方法:

capitalize():将字符串第⼀个字符转换成⼤写。
title():将字符串每个单词⾸字⺟转换成⼤写
lower():将字符串中⼤写转⼩写。
upper():将字符串中⼩写转⼤写。

3. 判断

判断所涉及到的函数返回值为布尔类型,当符合条件时,返回值为true。

startswith():检查字符串是否是以指定⼦串开头。

语法:字符串序列.startswith(⼦串, 开始位置下标, 结束位置下标)

endswith():检查字符串是否是以指定⼦串结尾

语法:字符串序列.endswith(⼦串, 开始位置下标, 结束位置下标)

isalpha():判断字符串是否⾄少有⼀个字符并且所有字符都是字⺟
isdigit():判断字符串是否只包含数字
isalnum():判断字符串是否⾄少有⼀个字符并且所有字符都是字⺟或数字
isalnum():如果字符串⾄少有⼀个字符并且所有字符都是字⺟或数字

致谢

本文编写时参考了黑马程序员中相关的资料,在此特别感谢,如有侵犯,请联系我。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值