Python开发——数据类型【字符串】
字符串定义
字符串是一个有序的字符的集合,用于存储和表示基本的文本信息
在Python中加了引号的字符,都被认为是字符串!
单引号、双引号、多引号之间的区别? 答案:单双引号没有区别
多引号的作用? 答案:多行字符串必须用引号
字符串的特性
字符串是按照从左向右的顺序定义字符集和,下标从0开始顺序访问,有序。
补充:
字符串的单引号和双引号都无法取消特殊字符的含义,
如果想让引号内所有字符均取消特殊意义,在引号前面加r,如 name = r'l\thf'。
unicode字符串与r连用必须在r前面,如 name = ur'l\thf'。
字符串一旦创建,不可修改,当字符串修改或者拼接,将会重新生成字符串
字符串常用操作
字符串拼接
- # 字符串的拼接,只能双方都是字符串
- name= 'Lucy '
- age= ''
- print(name+age) # Lucy 18
- print(name*10) # 复制自身10次,再拼接在一起
- # Lucy Lucy Lucy Lucy Lucy Lucy Lucy Lucy Lucy Lucy
索引
- s = 'hello'
- print(s[1]) # e
- print(s[-1]) # o
- print(s.index('e')) #
查找
- s = 'hello'
- print(s.find('o')) #
- print(s.find('i')) # -1
长度
- s = 'hello world'
- print(len(s)) #
切片
- s = 'abcdefghijklmn' # 左闭[、右开)、步长
- print(s[0:7]) # abcdefg
- print(s[:7]) # abcdefg
- print(s[0:7:2]) # aceg
- print(s[:7:2]) # aceg
- print(s[7:14]) # hijklmn
- print(s[7:]) # hijklmn
- print(s[7:14:3]) # hkn
- print(s[7::3]) # hkn
- print(s[:]) # abcdefghijklmn
- print(s[::2]) # acegikm
- print(s[::-1]) # nmlkjihgfedcba
字符串函数
In 的使用
- s = "helloworld"
- if "l" in s:
- print("ok")
- for items in "hello":
- print(items)
字符串拼接join
- # 将字符串中的每一个元素按照指定分隔符进行拼接
- s = "PYTHON"
- v = "_".join(s)
- print(v) # P_Y_T_H_O_N
字符串大小写转换
- # capitalize 首字母大写
- s = 'hello world'
- v = s.capitalize()
- print(v) # Hello world
- # casefold 大写转小写
- s = 'Hello WORLD'
- v = s.casefold()
- print(v) # hello world
- # lower 大写转小写
- v = s.lower()
- print(v) # hello world
- # 判断是否全部是大(小)写 和 转换为小(大)写
- s = "Hello World"
- v = s.islower()
- print(v) # False
- v = s.lower()
- print(v) # hello world
- v = s.isupper()
- print(v) # False
- v = s.upper()
- print(v) # HELLO WORLD
- # 大写转小写,小写转大写
- v = s.swapcase()
- print(v) # hELLO wORLD
字符串分割
- # 分割为三部分
- s = "testasdsddfg"
- v = s.partition("s") # 以字符出现的第一个位置分割
- print(v) # ('te', 's', 'tasdsddfg')
- v = s.rpartition("s") # 以字符出现的最后一个位置分割
- print(v) # ('testasd', 's', 'ddfg')
- # 分割为指定数量处
- v = s.split("s",2) # 以字符出现的前两个位置处分割
- print(v) # ['te', 'ta', 'dsddfg']
- v = s.rsplit("s",2) # 以字符出现的最后两个位置处分割
- print(v) # ['testa', 'd', 'ddfg']
- # 换行分割
- s = "asdfadfasdf\nasdfasdf\nadfasdf"
- v = s.splitlines() # 默认为False
- print(v) # ['asdfadfasdf', 'asdfasdf', 'adfasdf']
- v = s.splitlines(True)
- print(v) # ['asdfadfasdf\n', 'asdfasdf\n', 'adfasdf']
字符串移除
- # 移除指定字符串
- # 有限最多匹配
- s = "Alex"
- v1 = s.strip("ex") # Al
- v2 = s.lstrip("Al") # ex
- v3 = s.rstrip("ex") # Al
- print(v1)
- print(v2)
- print(v3)
- print("*************")
- # 去除左右空白
- s = " hello world "
- v1 = s.strip() # hello world
- v2 = s.lstrip() # hello world
- v3 = s.rstrip() # hello world
- print(v1)
- print(v2)
- print(v3)
- print("*************")
- # 去除\t \n
- s = "\thello world"
- v1 = s.strip()
- v2 = s.lstrip()
- v3 = s.rstrip()
- print(s) # hello world
- print(v1) # hello world
- print(v2) # hello world
- print(v3) # hello world
字符串格式化
- # format格式化
- s = 'I am {name},I am {age}'
- v = s.format(name = 'yuan',age = '')
- print(v) # I am yuan,I am 18
- v = s.format_map({'name':'yuan','age':''})
- print(v) # I am yuan,I am 18
- s = 'I am {0},I am {1}'
- v = s.format('yuan','')
- print(v) # I am yuan,I am 18
字符串替换
- # 将指定字符串替换为指定字符串
- s = "Hello World"
- v = s.replace("o","k")
- print(v) # Hellk Wkrld
- v = s.replace("o","k",1) # (旧字符串、新字符串、数量)
- print(v) # Hellk World
字符串子序列查找
- # count 在字符串中寻找,查找子序列的出现次数
- s = "aLexalexr"
- v = s.count("ex")
- print(v) #
- v = s.count("ex",5,6) # (子序列,起始位置,结束位置)
- print(v) #
tab填充
- # expandtabs 设置字符串长度,其余用tab键,\t 填充
- s = "username\temail\tpassword\nlaiying\tying@q.com\t123\nlaiying\tying@q.com\t123\nlaiying\tying@q.com\t123"
- v = s.expandtabs(20)
- print(v)
- # username email password
- # laiying ying@q.com 123
- # laiying ying@q.com 123
- # laiying ying@q.com 123
以···开头(结尾)
- # startswith 以。。。开始
- # endswith 以。。。结尾
- s = "Hello World"
- v = s.endswith("ld")
- print(v) # True
- v = s.startswith('He')
- print(v) # True
判断字符串
- # 判断字符串 是否为标题
- s = "I am a girl"
- v = s.istitle()
- print(v) # False
- v = s.title()
- print(v) # I Am A Girl
- v = v.istitle()
- print(v) # True
- # 判断 字符串中是否只包含 字母和数字
- s = '123ada'
- v = s.isalnum()
- print(v) # True
- # 判断 字符串中是否只包含 字母和汉字
- s = 'asas我是'
- v = s.isalpha()
- print(v) # True
- # 判断是否为数字
- s = "②"
- v1 = s.isdecimal()
- v2 = s.isdigit()
- v3 = s.isnumeric()
- print(v1,v2,v3)
- # s = "二" False False True
- # s = "1" True True True
- # s = "②" False True True
- # 判断字符串 是否存在不可显示的字符
- # 如:\n、\t
- s = 'asdf\tasd'
- v = s.isprintable()
- print(v) # False
- # 判断字符串 是否为空格
- s = " " # 若"",则False
- v = s.isspace()
- print(v) # True
字符串设置宽度及填充
- # center 设置宽度,并将内容居中
- s = 'Hello World'
- v = s.center(20) # 20 指字符串总长度
- print(v) # Hello World
- v = s.center(20,"*") # * 为空白填充【可无】
- print(v) # ****Hello World*****
- v = s.ljust(20,"*")
- print(v) # Hello World*********
- v = s.rjust(20,"*")
- print(v) # *********Hello World
- v = s.zfill(20)
- print(v) # 000000000Hello World
对应关系替换maketrans、translate
isidentifier【】
- # identifier:识别符; 检验人,标识符; 鉴别器; 编号
- # 字母,数字,下划线 : 标识符 def class
- s = "asdfghjk"
- v = s.isidentifier()
- print(v) # True
- # s = "123" False
- # s = "class" True
Python开发——数据类型【字符串】的更多相关文章
- Python基础数据类型-字符串(string)
Python基础数据类型-字符串(string) 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 本篇博客使用的是Python3.6版本,以及以后分享的每一篇都是Python3.x版 ...
- Python开发——数据类型【字符串格式化】
字符串格式化之——% # 字符串格式化 msg = 'I am %s , My hobby is %s'%('yuan','play') print(msg) # I am yuan , My hob ...
- Python之路(第三篇):Python基本数据类型字符串(二)
一.基本数据类型1.字符串 str字符串方法介绍(二)a --expandtabs( ) expandtabs( ) 把字符串中的 tab 符号('\t')转为空格参数默认为8,注意字符串原有的空格也 ...
- Python之路(第二篇):Python基本数据类型字符串(一)
一.基础 1.编码 UTF-8:中文占3个字节 GBK:中文占2个字节 Unicode.UTF-8.GBK三者关系 ascii码是只能表示英文字符,用8个字节表示英文,unicode是统一码,世界通用 ...
- python 基本数据类型--字符串实例详解
字符串(str) :把字符连成串. 在python中⽤', ", ''', """引起来的内容被称为字符串 . 注意:python中没有单一字符说法,统一称叫字 ...
- Python开发——数据类型【列表】
列表的定义 中括号[]内以逗号分隔开,按照索引,存放各种数据类型,每个位置代表一个元素 list_t = ['张三','Lucy',123] print(list_t) # ['张三', 'Lucy' ...
- Python开发——数据类型【字典】
字典的定义 # Python语言中唯一的类型映射 # 键与值之间用“:”分开 # 项与项之间用“,”分开 person = {"name":"yuan",&qu ...
- python开发_difflib字符串比较
在python的difflib中 HtmlDiff:比较后以html方法展示 我们比较的是字符串: 'hello world!' 和 'hElLO Wor2d!' 具体代码: from difflib ...
- Python基础——数据类型——字符串
整数.浮点数.布尔值的用法大同小异,而Python字符串的一些用法不易记住,这里以廖雪峰教程为基础,进行一些思考和复习总结. 字符串是什么? 以单引号'或者双引号"括起来的任意文本,比如:& ...
随机推荐
- dos2unix 批量转化文件
在windows和linux双平台下开发,同时也用git作为同步工具,但前期没有注意,导致很多文件使用windows下的换行符CRLF 参考资料了解dos2unix可以转化格式. 但有个问题,虽然可以 ...
- putty安装和使用
https://blog.csdn.net/l707941510/article/details/80520790
- 【Python】断言功能Assertion
转自 https://www.cnblogs.com/cicaday/p/python-assert.html Python Assert 为何不尽如人意 Python中的断言用起来非常简单,你可以在 ...
- Kubernetes Kubelet安全认证连接Apiserver
Kubelet使用安全认证连接Apiserver,可以用Token或证书连接.配置步骤如下. 1,生成Token命令 head -c /dev/urandom | od -An -t x | tr - ...
- access数据库编号转换成统一3位数长度方法,不足3位前面补零
select C_CUN+Format(Val(NZ(C_LB)),"000") from LBM 这条SQL只能在access数据库中执行,因为sql不支持NZ函数,而且c_lb ...
- 将打印(printk/printf)及时写入文件的方法
问题是这样的,在测试一个gps的app的时候,我使用脚本 “ gps_test_app > /tmp/gps_log.txt &" 但是但是,去查看gps_log.txt的 ...
- Python中print字体颜色的设置
Python中print字体颜色的设置 实现过程: 终端的字符颜色是用转义序列控制的,是文本模式下的系统显示功能,和具体的语言无关. 转义序列是以ESC开头,即用\033来完成 ...
- 自然语言处理NLP-云端API汇总
Google Google Cloud:https://cloud.google.com/natural-language/ ParallelDots ParallelDots, Inc. 无需训练, ...
- k8s学习笔记之八:存储卷
第一章.前言 默认情况下容器的数据都是非持久化的, 在容器消亡以后数据也跟着丢失, 所以 Docker 提供了 Volume 机制以便将数据持久化存储. 类似的, Kubernetes 提供了更强大的 ...
- Java内存泄漏的几种可能
Java内存泄漏引起的原因: 内存泄漏是指无用对象(不再使用的对象)持续占有内存或无用对象的内存得不到及时释放,从而造成内存空间的浪费称为内存泄漏. 长生命周期的对象持有短生命周期对象的引用就很可能发 ...