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():如果字符串⾄少有⼀个字符并且所有字符都是字⺟或数字

致谢

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

### Python 字符串处理方法和函数 #### 字符串定义 字符串Python 中最常用的数据类型之一,它们可以用单引号或双引号来表示[^1]。 ```python single_quoted_string = 'Hello, world!' double_quoted_string = "Hello, universe!" ``` #### 基本字符串操作函数 ##### 拼接字符串 可以通过加号 `+` 来实现两个字符串的拼接: ```python greeting = "Hello" name = "Alice" message = greeting + ", " + name # 输出: Hello, Alice ``` ##### 分割字符串 使用 `split()` 函数可以根据指定分隔符将字符串分割成列表: ```python text = "apple,banana,cherry" fruits = text.split(",") # ['apple', 'banana', 'cherry'] ``` ##### 查找子串位置 利用 `find()` 或者 `index()` 可以找到某个子串首次出现的位置;如果找不到,则 `find()` 返回 `-1` 而 `index()` 抛出异常: ```python sentence = "Welcome to the jungle." position_find = sentence.find("jungle") # position_find=11 try: position_index = sentence.index("desert") except ValueError as e: print(e) # substring not found ``` ##### 替换子串 通过 `replace(old, new)` 将旧子串替换成新子串: ```python old_text = "I like cats and dogs." new_text = old_text.replace("cats", "rabbits") # I like rabbits and dogs. ``` ##### 大小写转换 支持多种大小写的转换方式,比如全部大写、首字母大写等: ```python lowercase = "hello".upper() # HELLO uppercase = "WORLD".lower() # world capitalized = "john doe".capitalize() # John doe titlecased = "john DOE".title() # John Doe ``` #### 特殊字符处理 ##### 去除空白字符 为了去除字符串两端多余的空格或其他空白字符,可以采用 `strip()` 方法。此方法会移除开头和结尾处所有的空白字符(包括空格、制表符 `\t` 和换行符 `\n`),但不会影响中间部分的任何空白字符[^2]。 ```python trimmed_string = ' hello there! '.strip() print(trimmed_string) # hello there! ``` #### 序列转字符串 当有一个由多个项组成的序列并希望将其组合成单一字符串时,可借助于 `join()` 方法。该方法接收一个迭代器作为参数,并用给定的分隔符把各个元素连在一起形成一个新的字符串对象[^3]。 ```python words_list = ["Python", "is", "awesome"] joined_sentence = "-".join(words_list) print(joined_sentence) # Python-is-awesome ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值