python字符串常用操作

1、转义字符

在python字符串中输入下列转义字符来输出特定的字符

\'  单引号     

\"  双引号

\t  制表符

\n  换行符

\\  到斜杠

2、Python字符串运算符(a='Hello',b='Python')

+     字符串连接         a + b    'HelloPython'

*      重复输出字符串       a * 2    'HelloHello'

[]     通过索引获取字符串中字符  a[1]     'e'

[:]    截取字符串中的一部分    a[1:4]    'ell'

in      成员运算符 - 如果字符串中包含给定的字符返回 True

not in  成员运算符 - 如果字符串中不包含给定的字符返回 True

r/R     原始字符串 - 原始字符串:所有的字符串都是直接按照字面的意思来使用,没有转义特殊或不能打印的字符。 原始字符串除在字符串的第一个引号前加上字母"r"(可以大小写)以外,与普通字符串有着几乎完全相同的语法。>>>print(r'\n')   \n

%    格式字符串    python字符串格式化使用与 C 中 sprintf 函数一样的语法

>>>print('My name is %s '%('98peiqi'))

My name is 98peiqi

字符串格式化符号:

%c    格式化字符及其ASCII码
%s    格式化字符串
%d    格式化整数
%u    格式化无符号整型
%o    格式化无符号八进制数
%x    格式化无符号十六进制数
%X    格式化无符号十六进制数(大写)
%f    格式化浮点数字,可指定小数点后的精度
%e    用科学计数法格式化浮点数
%E    作用同%e,用科学计数法格式化浮点数
%g    %f和%e的简写
%G    %f 和 %E 的简写
%p    用十六进制数格式化变量的地址 

3、三重引号

print函数打印多行字符串时可使用三重引号输出,三重引号之间的所有引号、制表符或者换行符都会被认为是字符串的一部分,并且python的代码块缩进规则不适用于多行字符。

在函数外面,三重引号之间的所有字符被视为注释

4、字符串方法

upper()     返回一个新字符串,其中原字符串的所有字母被相应的转换为大写

lower()     返回一个新字符串,其中原字符串的所有字母被相应的转换为小写

isupper()    如果字符串中至少有一个字母,且所有字母都是大写,则返回True,否则返回False

islower()     如果字符串中至少有一个字母,且所有字母都是小写,则返回True,否则返回False

isalpha()    如果字符串只包含字母,且非空则返回True,否则返回False

isalnum()     如果字符串只包含字母和数字,且非空则返回True,否则返回False

isdecimal()   如果字符串只包含数字字符,且非空则返回True,否则返回False

isspace()     如果字符串只包含空格、制表符和换行符,且非空则返回True,否则返回False

istitle()   如果字符串只包含以大写字母开头、后面都是小写字母的单词则返回True,否则返回False

title()     方法返回"标题化"的字符串,就是说所有单词的首个字母转化为大写,其余字母均为小写

swapcase()    方法用于对字符串的大小写字母进行转换。

translate()   方法根据参数table给出的表(包含 256 个字符)转换字符串的字符,要过滤掉的字符放到 deletechars 参数中。

  方法语法:

  str.translate(table)   bytes.translate(table[, deletechars])   bytearray.translate(table[, deletechars])

 

startswith(一个字符串或者是一个元素[, start[, end]])   如果所调用的字符串以该方法传入的字符串开始则返回True,否则返回False     #start 参数以 0 为第一个字符索引值。

endswith  (一个字符串或者是一个元素[, start[, end]])   如果所调用的字符串以该方法传入的字符串结束则返回True,否则返回False     #end 参数以 1 为第一个字符索引值。

strip ([chars])    删除字符串两边指定字符,默认为空格

rstrip([chars])    删除字符串右边指定字符,默认为空格

lstrip([chars])    删除字符串左边指定字符,默认为空格

max(str)      方法返回字符串中最大的字母。

min(str)      方法返回字符串中最小的字母。

rjust (宽度[,填充字符])      返回指定宽度右对齐,空白部分用填充字符填充

ljust (宽度[,填充字符])      返回指定宽度左对齐,空白部分用填充字符填充

center(宽度[,填充字符])      返回指定宽度居中  ,空白部分用填充字符填充         #宽度小于字符串长度时,输出不变

'填充字符'.join(要连接的元素序列)       将一个字符串列表连接起来成为一个独立的字符串,连接符为填充字符

'字符串'.split('分隔字符'[,分隔次数])   将字符串以分隔字符为标记分隔成一个字符串列表  #常用以换行符分隔,默认以空格分隔,分割次数默认为-1,即分隔所有

str.splitlines([keepends])    按照行('\r', '\r\n', \n')分隔,返回一个包含各行作为元素的列表,如果参数 keepends 为 False,不包含换行符,如果为 True,则保留换行符。

capitalize()    将字符串的第一个字母变成大写,其他字母变小写。 

>>> a = 'this is 98peiqi'
>>> print(a.capitalize())
This is 98peiqi

count(sub, start= 0,end=len(string))  统计字符串里某个字符出现的次数。可选参数为在字符串搜索的开始与结束位置。

sub -- 搜索的子字符串

start -- 字符串开始搜索的位置。默认为第一个字符,第一个字符索引值为0。

end -- 字符串中结束搜索的位置。默认为字符串的最后一个位置。

>>> a='there are two peiqis,a peiqi is tall ,another peiqi is short'
>>> print(a.count('peiqi'))
3

encode(encoding='UTF-8',errors='strict')         方法以指定的编码格式编码字符串。errors参数可以指定不同的错误处理方案。

bytes.decode(encoding="utf-8", errors="strict")  方法以指定的编码格式解码 bytes 对象。默认编码为 'utf-8'。

encoding -- 要使用的编码,如"UTF-8"。

errors -- 设置不同错误的处理方案。默认为 'strict',意为编码错误引起一个UnicodeError。 其他可能得值有 'ignore', 'replace', 'xmlcharrefreplace', 'backslashreplace' 以及通过 codecs.register_error() 注册的任何值。

>>> a = '佩奇'
>>> print(a.encode('GBK'))
b'\xc5\xe5\xc6\xe6'
>>> print(a.encode())
b'\xe4\xbd\xa9\xe5\xa5\x87'

>>> b = b'\xc5\xe5\xc6\xe6'
>>> print(b.decode('GBK'))
佩奇

expandtabs(转为空格的字符数)       方法把字符串中的 tab 符号('\t')转为空格,tab 符号('\t')默认的空格数是 8。

find(str, beg=0, end=len(string))  方法检测字符串中是否包含子字符串 str ,如果指定 beg(开始) 和 end(结束) 范围,则检查是否包含在指定范围内,如果指定范围内如果包含指定索引值,返回的是索引值在字符串中的起始位置。如果不包含索引值,返回-1。

 rfind(str, beg=0 end=len(string))  返回字符串最后一次出现的位置,如果没有匹配项则返回-1。

 index(str, beg=0, end=len(string)方法检测字符串中是否包含子字符串 str ,如果指定 beg(开始) 和 end(结束) 范围,则检查是否包含在指定范围内,该方法与 python find()方法一样,只不过如果str不在 string中会报一个异常。

rindex(str, beg=0 end=len(string)返回子字符串 str 在字符串中最后出现的位置,如果没有匹配的字符串会报异常,你可以指定可选参数[beg:end]设置查找的区间。

str.maketrans(intab, outtab) 方法用于创建字符映射的转换表,对于接受两个参数的最简单的调用方式,第一个参数是字符串,表示需要转换的字符,第二个参数是字符串表示转换的目标。两个字符串的长度必须相同,为一一对应的关系。#Python3.4 已经没有 string.maketrans() 了,取而代之的是内建函数: bytearray.maketrans()、bytes.maketrans()、str.maketrans() 。

>>> a='01234567890'
>>> b='           '
>>> c=str.maketrans(a,b)
>>> str1='aqw1qwrr3as18f4as6d8'
>>> print(str1.translate(c))
aqw qwrr as f as d

str.replace(old, new[, max])       方法把字符串中的 old(旧字符串) 替换成 new(新字符串),如果指定第三个参数max,则替换不超过 max 次。

str.zfill(width)               方法返回指定长度的字符串,原字符串右对齐,前面填充0。

 

转载于:https://www.cnblogs.com/98peiqi/p/11186543.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值