返回总目录页

python基础知识-03-字符串

 

python其他知识目录

 

1、for循环遍历字符串中单个字符

s_str="mcw"
for i in s_str:
print(i)
-----------结果:
m
c
w

2、#计算字符串长度

s_str="mcw"
mcw_len=len(s_str)
print(mcw_len)
------------结果:
3

3、#字符串索引

m_str="mcw"
print(m_str[0],m_str[2],m_str[1])
-----------结果:
m w c

4、#让用户输入任意字符串,获取字符串之后并计算其中有多少个数字isdigit()

text=input("请输入内容:")
index_len=len(text)
index=0
while True:
val=text[index]
print(val)
if index==index_len -1:
break
index+=1

text=input("请输入内容:")
index_len=len(text) #输入字符串的长度,
index=0 #字符串的下角标,下角标为[0,index_len-1]
count=0 #对数字个数进行计数
while True:
val=text[index]
if val.isdigit():
print(val)
count+=1
if index==index_len -1:
break
index+=1
print("数字总共有%s个"%(count))
-----------------结果:
请输入内容:mcwff9023ff
9
0
2
3
数字总共有4个

实现步骤思路:

1、用的是while对输入字符串进行循环打印(while循环字符串需要统计字符串长度,开
头和结尾数字)
2、判断字符是否为数字,打印出数字来
3、初始化一个计数变量,多一个数字就自增一对个数进行统计。

5、#索引取值,从前向后,从后向前取。


6、#切片和索引

-----------------
         01234 
mcw_str
="mcwhr" ------------------ print(mcw_str[0],mcw_str[2],mcw_str[4]) m w r ------------------- print(mcw_str[-1],mcw_str[-2],mcw_str[-3],mcw_str[-4],mcw_str[-5]) r h w c m ------------------ print(mcw_str[2:4],mcw_str[3:-1],mcw_str[2:],mcw_str[:-1],mcw_str[:3]) wh h whr mcwh mcw
自我注解:
[2:4]取下标2,3,不包含4;[3:-1],取指定下标3到最后一个,-1为倒数第一个,不包含最后一个;[2:],从指定下标到最后一个,包含最后一个;[:-1],取下标从0到
最后一个,不包含最后一个;[:3],从开头到下标2做操作,不包含下标3
--------------------
[::]取所有 [::-1]倒着取,步长为1

取最后两个字符[-2:],或者[字符总长度-2,字符总长度],len().

mcw_str="mcwhr"
print(mcw_str[-2:])
hr

mcw_str="mcwhr"
total_len=len(mcw_str)
v=mcw_str[total_len-2:total_len]
print(v)
hr

错误:IndexError: string index out of range

原因:索引超出范围了。

mcw="sfsf"
print(mcw[7])

7、#字符串操作split,#有时间添加awk的切割做对比


split():拆分字符串。通过指定分隔符对字符串进行切片,并返回分割后的字符串列表(list)

1、split()函数
语法:str.split(str="",num=string.count(str))[n]

参数说明:
str:表示为分隔符,默认为空格,但是不能为空('')。若字符串中没有分隔符,则把整个字符串作为列
表的一个元素
num:表示分割次数。如果存在参数num,则仅分隔成 num+1 个子字符串,并且每一个子字符串可以赋给
新的变量
[n]:表示选取第n个分片

注意:当使用空格作为分隔符时,对于中间为空的项会自动忽略


string = "www.mcw.com.cn"

1.以'.'为分隔符              #指定分隔符切割

print(string.split('.'))

['www', 'mcw', 'com', 'cn']

 

2.分割两次         #指定分隔符,指定切割次数

print(string.split('.',2))

['www', 'mcw', 'com.cn']

 

3.分割两次,并取序列为1的项     #指定分隔符,指定次数切割并取指定下标的元素。

print(string.split('.',2)[1])

mcw

 

4.分割两次,并把分割后的三个部分赋值给三个变量。    #指定分隔符,指定次数分割。分割结果赋值给(次数+1)个变量(疑问,赋值变量个数可以少点吗?)

u1, u2, u3 =string.split('.',2)

print(u1)—— www

print(u2)—— mcw

print(u3) ——com.cn

-----------------------------

5、一个复杂的切割案例:
mcwstr="hello mcw<[www.baidu.com]>byebye"

 

1)print(mcwstr.split("[")[1])
www.baidu.com]>byebye

    2)print(mcwstr.split("[")[1].split("]")[0])

         www.baidu.com

    3)print(mcwstr.split("[")[1].split("]")[0].split("."))
   ['www', 'baidu', 'com']
参考文章:https://www.cnblogs.com/liujiacai/p/7839971.html
https://blog.csdn.net/ll18810775652/article/details/78575066

6、split默认以空格为分隔符

name="xiao ma guo he"
print(name.split())
--------结果:
['xiao', 'ma', 'guo', 'he']

8、#字符串操作isdigit使用

mcw1="a"
mcw2="2"
mcw3="8b"
n1=mcw1.isdigit()
n2=mcw2.isdigit()
n3=mcw3.isdigit()
print(n1,n2,n3)
---------------结果: #False True False
#自我注解:只要是数字返回值就是True.由此判定字符是否为数字。

#让用户输入任意字符串,获取字符串之后病计算其中有多少个数字

text=input("请输入内容:")
index_len=len(text) #输入字符串的长度,
index=0 #字符串的下角标,下角标为[0,index_len-1]
count=0 #对数字个数进行计数
while True:
val=text[index]
if val.isdigit():
print(val)
count+=1
if index==index_len -1:
break
index+=1
print("数字总共有%s个"%(count))
------------------结果:
请输入内容:mcwff9023ff
9
0
2
3
数字总共有4个

实现步骤思路:

1、用的是while对输入字符串进行循环打印(while循环字符串需要统计字符串长度,开 
头和结尾数字)
2、判断字符是否为数字,打印出数字来
3、初始化一个计数变量,多一个数字就自增一对个数进行统计。

9、#字符串操作upper和lower

mcw1="MCcI"
mcw2="mKlsM"
print(mcw1.lower(),mcw2.upper())
-----------------结果:
mcci MKLSM


mcw="mCwfeIhAo xIao"
mcwmodify=mcw[0:1].upper()+mcw[1:len(mcw)].lower()
mm=mcw[:-3].lower()+mcw[-3:].upper()
print(mcwmodify)
print(mm)
----------------结果:

Mcwfeihao xiao
mcwfeihao xIAO

#自我注解: 对字符串大小写进行转换,也可以对字符串先切片再转换大小写,用+号拼接起来。

      可指定字符转换大小写,当结合切片的时候

10、#字符串操作strip(),lstrip(),rstrip()

参考:https://www.cnblogs.com/huangbiquan/p/7923008.html

Python中有三个去除头尾字符、空白符的函数,它们依次为:

strip: 用来去除头尾字符、空白符(包括\n、\r、\t、' ',即:换行、回车、制表符、空格)
lstrip:用来去除开头字符、空白符(包括\n、\r、\t、' ',即:换行、回车、制表符、空格)
rstrip:用来去除结尾字符、空白符(包括\n、\r、\t、' ',即:换行、回车、制表符、空格)
注意:这些函数都只会删除头和尾的字符,中间的不会删除。

用法分别为:
string.strip([chars])
string.lstrip([chars])
string.rstrip([chars])

参数chars是可选的,当chars为空,默认删除string头尾的空白符(包括\n、\r、\t、' ')
当chars不为空时,函数会被chars解成一个个的字符,然后将这些字符去掉。

它返回的是去除头尾字符(或空白符)的string副本,string本身不会发生改变。

举例说明如下:
1. 当chars为空时,默认删除空白符(包括'\n', '\r', '\t', ' ')

m_str=" xiao ma "
print("---|"+m_str+"|---") #原字符串打印
print("---|"+m_str.strip()+"|----") #删除头尾空格
print("---|"+m_str.lstrip()+"|---") #删除开头空格
print("---|"+m_str.rstrip()+"|---") #删除结尾空格
显示结果:
---| xiao ma |---
---|xiao ma|----
---|xiao ma |---
---| xiao ma|---


2.当chars不为空时,函数会被chars解成一个个的字符,然后将这些字符去掉。

m_str="122xiao12ma2"
print(m_str) #原字符串打印
print(m_str.strip("12")) #删除头尾指定字符串
print(m_str.lstrip("12")) #删除开头指定字符串
print(m_str.rstrip("12")) #删除结尾指定字符串

结果:
122xiao12ma2
xiao12ma
xiao12ma2
122xiao12ma


3、字符串也可以变量代替
a = 'x'
b = 'xiaoma'
print(b.lstrip(a))

iaoma

4、
a="c:\acmacm"
b="c:\a\cmcw"
print(b.strip(a))

\cmcw #去除变量b中与变量a开头相同的部分。

 5、#去制表符,换行符

v1="mcw\nxiaoma"
v2="mcw \t xiaoma"
print(v1)
print("------------------------")
print(v2)
print("---------------------------")
v3="mcw\n"                                   #去制表符,换行符
v4="xiaoma\t"
print(v3.strip(),v4.strip())    

 6、默认同时去掉制表符,换行符,空格这些

ss="  \t   mcw\n   "
li=[]
li.append(ss)
li.append(ss.strip())
print(li)
------------------结果:
['  \t   mcw\n   ', 'mcw']

 

posted @ 2019-03-29 18:36  马昌伟  阅读(612)  评论(0编辑  收藏  举报
博主链接地址:https://www.cnblogs.com/machangwei-8/