# 1、作用 # 2、定义 # msg='hello' # msg=str('msg') # print(type(msg)) # 3、类型转换 # str可以把任意其他类型都转成字符串 # res=str({'a':1}) # print(res,type(res)) # 4、使用:内置方法 # 4.1 优先掌握 # 4.1.1、按索引取值(正向取+反向取) :只能取,不能改 msg='hello world' # 正向取 # print(msg[0]) # print(msg[5]) # 反向取 # print(msg[-2]) # 注意反向取时第一个值是从-1开始算的,-1,-2,-3,-4.。。。。。。。 # 只能取 字符串是str类型,是不可变类型,只能取不能修改 # msg[0]='H' # 会显示错误 # 4.1.2、切片:索引的拓展应用,从一个大字符串中拷贝出一个子字符串 msg='hello world' # 顾头不顾尾 # res=msg[0:5] #x # print(res) # print(msg) # 步长 # res=msg[0:5:2] # 0 2 4 注意:这个地方的步长前面要用 : 表示,不像range里面一样使用 , # print(res) # hlo # 反向步长(了解) # res=msg[6:0:-1] # 此处的是从第六位位数的5向第一位数的0进行反向取值,因此步长也要是反方向的 # print(res) #" olle" # 这个反向步长,反向的顾头不顾尾,所以永远取不到第一位数 # msg='hello world' # res=msg[:] # res=msg[0:11] # print(res) # # res=msg[::-1] # 把字符串倒过来 # 反向切片,-1表示从右往左依次取值 # print(res) # 4.1.3、长度len :计算字符串长度 # msg='hello world' # print(len(msg)) # 4.1.4、成员运算in和not in # 判断一个子字符串是否存在于一个大字符串中 # print("alex" in "alex is sb") # print("alex" not in "alex is sb") # print(not "alex" in "alex is sb") # 不推荐使用 # 4.1.5、移除字符串左右两侧的符号strip # 默认去掉的空格 # msg=' egon ' # res=msg.strip() # print(msg) # 不会改变原值 # print(res) # 是产生了新值 # 默认去掉的空格 # msg='****egon****' # print(msg.strip('*')) # 了解:strip只取两边,不去中间 # msg='****e*****gon****' # print(msg.strip('*')) # msg='**/*=-**egon**-=()**' # print(msg.strip('*/-=()')) # 应用 # inp_user=input('your name>>: ').strip() # inp_user=" egon" # inp_pwd=input('your password>>: ').strip() # if inp_user == 'egon' and inp_pwd == '123': # print('登录成功') # else: # print('账号密码错误') # 4.1.6、切分split:把一个字符串按照某种分隔符进行切分,得到一个列表 # # 默认分隔符是空格 # info='egon 18 male' # res=info.split() # print(res) # # 指定分隔符 # info='egon:18:male' # res=info.split(':') # print(res) # 指定分隔次数(了解) # info='egon:18:male' # res=info.split(':',1) # print(res) # 4.1.7、循环 # info='egon:18:male' # for x in info: # print(x) # 4.2 需要掌握 #4.2.1、strip(去字符串两侧的符号),lstrip(去字符串左侧的符号),rstrip(去字符串右侧的符号) # msg='***egon****' # print(msg.strip('*')) # print(msg.lstrip('*')) # print(msg.rstrip('*')) #4.2.2、lower(把字符串全变成小写),upper(把字符串全变成大写) # msg='AbbbCCCC' # print(msg.lower()) # print(msg.upper()) #4.2.3、startswith,endswith # print("alex is sb".startswith("alex")) # print("alex is sb".endswith('sb')) #4.2.4、format 下面是关于.format的各种使用方法 ''' https://blog.csdn.net/qq_45726327/article/details/115042863?ops_request_misc =%257B%2522request%255Fid%2522%253A%2522167676788516782428684627%2522%252C%2 522scm%2522%253A%252220140713.130102334..%2522%257D&request_id=1676767885167824 28684627&biz_id=0&utm_medium=distribute.pc_search_result.none-task-blog-2~all~t op_positive~default-1-115042863-null-null.142^v73^insert_down2,201^v4^add_ask, 239^v2^insert_chatgpt&utm_term=.format&spm=1018.2226.3001.4187 ''' #4.2.5、split,rsplit:将字符串切成列表 # info="egon:18:male" # print(info.split(':',1)) # ["egon","18:male"] # print(info.rsplit(':',1)) # ["egon:18","male"] #4.2.6、join: 把列表拼接成字符串 # l=['egon', '18', 'male'] # res=l[0]+":"+l[1]+":"+l[2] # res=":".join(l) # 按照某个分隔符号,把元素全为字符串的列表拼接成一个大字符串 # print(res) # l=[1,"2",'aaa'] # ":".join(l) #4.2.7、replace(替代) # msg="you can you up no can no bb" # print(msg.replace("you","YOU",)) # print(msg.replace("you","YOU",1)) #4.2.8、isdigit # 判断字符串是否由纯数字组成,必须是正整数才可以 # print('123'.isdigit()) # print('12.3'.isdigit()) # age=input('请输入你的年龄:').strip() # if age.isdigit(): # age=int(age) # int("abbab") # if age > 18: # print('猜大了') # elif age < 18: # print('猜小了') # else: # print('才最了') # else: # print('必须输入数字,傻子') # 4.3了解 #4.3.1、find,rfind,index,rindex,count msg='hello egon hahaha' # 找到返回起始索引 # print(msg.find('e')) # 返回要查找的字符串在大字符串中的起始索引 # print(msg.find('egon')) # print(msg.index('e')) # print(msg.index('egon')) # 找不到 # print(msg.find('xxx')) # 返回-1,代表找不到 # print(msg.index('xxx')) # 抛出异常,代码不能正常运行 msg='hello egon hahaha egon、 egon' print(msg.count('egon')) # 统计次数 #4.3.2、center,ljust,rjust,zfill # print('egon'.center(50,'*')) # print('egon'.ljust(50,'*')) #左填充 # print('egon'.rjust(50,'*')) #右填充 # print('egon'.zfill(10)) #默认的填充值是0 #4.3.3、expandtabs # msg='hello\tworld' # print(msg.expandtabs(2)) # 设置制表符代表的空格数为2 #4.3.4、captalize,swapcase,title # print("hello world egon".capitalize()) # 首字母大写 # print("Hello WorLd EGon".swapcase()) # 大小写反转 # print("hello world egon".title()) # 每个单词的首字母大写 #4.3.5、is数字系列 #4.3.6、is其他 # print('abc'.islower()) # print('ABC'.isupper()) # print('Hello World'.istitle()) # print('123123aadsf'.isalnum()) # 字符串由字母或数字组成结果为True # print('ad'.isalpha()) # 字符串由由字母组成结果为True # print(' '.isspace()) # 字符串由空格组成结果为True # print('print'.isidentifier()) # print('age_of_egon'.isidentifier()) # 判断你写的名字,关键字是否合法, # print('1age_of_egon'.isidentifier()) # 关键字有字母数字下划线组成,但是开头不能是数字 num1=b'4' #bytes num2=u'4' #unicode,python3中无需加u就是unicode num3='四' #中文数字 num4='Ⅳ' #罗马数字 # isdigit只能识别:num1、num2 # print(num1.isdigit()) # True # print(num2.isdigit()) # True # print(num3.isdigit()) # False # print(num4.isdigit()) # False # isnumberic可以识别:num2、num3、num4 # print(num2.isnumeric()) # True # print(num3.isnumeric()) # True # print(num4.isnumeric()) # True # isdecimal只能识别:num2 print(num2.isdecimal()) # True print(num3.isdecimal()) # False print(num4.isdecimal()) # False
总结:
索引msg=’hello world’ # print(msg[1])
注意:一定是使用[ ]括号才行 里面的数字代表着索引对应的位置 顾头不顾尾
正向取:第一个字符对应的是数字0
反向取:最后一个代表的是-1,以此为 -1,-2,-3,-4.。。。。。。。
msg=’hello world’ res=msg[0:5:2] # 0 2 4 步长为2
# 4.1.6、切分split:把一个字符串按照某种分隔符进行切分,得到一个列表 #
# 默认分隔符是空格
# info=’egon 18 male’
# res=info.split() 本身默认以空格为分隔符
# print(res)