码迷,mamicode.com
首页 > 编程语言 > 详细

python学习随笔(三)_字符串

时间:2018-08-11 16:46:48      阅读:228      评论:0      收藏:0      [点我收藏+]

标签:pre   效率   排版   精度   需要   表示   三元   magedu   ***   

字符串***
    是由一个个字符组成的有序的序列,是字符的集合
    使用单引号,双向引号,三引号引住的字符序列    #三引号中可以放sql语句
    字符串是不可变对象

字符串元素访问
    字符串支持使用索引访问
    有序列的字符集合,字符序列
    字符串可以是个容器,可以被一个个迭代出来,因为它是有顺序的

字符串join连接*
    "string".join(iterable) -> str
        将可迭代对象连接起来,使用string作为分隔符
        可迭代对象本身元素都是字符串
        ***返回一个新字符串
        #‘,‘.join()    #join后接字符串,‘‘中可以自定义间隔符
        #‘,‘.join(map(str,range(10)))

字符串+连接    #+ -> str
    #将2个字符串连接在一起
    #字符串相加产生新的字符串返回值为none

字符串分割*
    #分割字符串的方法分为2类
        #split系:将字符串按照分隔符分割成若干字符串,并返回列表
        #partition系:将字符串按照分隔符分割成2段,返回这2段和分隔符的元组
split(sep=None, maxsplit=-1) -> list of strings    #从左向右
    #sep可以改分隔符默认是空白字串作为分隔符
    # maxsplit 指定分割的次数,-1 表示遍历整个字符串
    ##返回类型是什么很重要  决定可不可以join
    #rsplit()          #从右向左切,用法一样

splitlines([keepends]) -> list of strings
    #按行切一行行切
    #keepends 指的是是否保留行分隔符
    # 行分隔符包括\n、\r\n、\r等

#常见换行符:/r,/n ,/r/n
#空白分隔符:空格,/t,/n

partition(sep) -> (head, sep, tail)
    #可以split的一个特例只切一回,带分隔符,但切完返回的是元组
    # 从左至右,遇到分隔符就把字符串分割成两部分,返回头、分隔符、尾三部分的三元组;如果没有找到分隔符,就返回头、2个空元素的三元组
    #sep分隔符字符串必须指定,不可以用空字符

切字符串比较常用:比如用在分行,文件路径路径,电话区号等等.

字符串大小写
    upper()        #全大写
    lower()        #全小写
    #大小写,做判断的时候用
    swapcase()    #交互大小写

字符串排版
    title() -> str    #标题的每个单词都大写
    capitalize() -> str    #首个单词大写
    center(width[, fillchar]) -> str
        #width 打印宽度
        #fillchar 填充的字符
        #格式:例:a.center(20,‘@‘)
    zfill(width) -> str
        #width 打印宽度,居右,左边用0填充
    ljust(width[, fillchar]) -> str 左对齐
    rjust(width[, fillchar]) -> str 右对齐
    #中文用的少,了解一下

字符串修改***
(替换)replace(old, new[, count]) -> str    #(替换)
    #字符串中找到匹配替换为新子串,返回新字符串
    #count表示替换几次,不指定就是全部替换
(删除) strip([chars]) -> str        #(两端去除)
    #从字符串两端去除指定的字符集chars中的所有字符
    #如果chars没有指定,去除两端的空白字符
lstrip([chars]) -> str        #从左开始
rstrip([chars]) -> str        #从右开始

字符串查找***    #返回索引号    #格式num.find(‘s‘,0,6)不指定数字从头开始找
find(sub[, start[, end]]) -> int
    #在指定的区间[start, end),从左至右,查找子串sub。找到返回索引,没找到返回-1
rfind(sub[, start[, end]]) -> int
    #在指定的区间[start, end),从右至左,查找子串sub。找到返回索引,没找到返回-1
index(sub[, start[, end]]) -> int
    #在指定的区间[start, end),从左至右,查找子串sub。找到返回索引,没找到抛出异常ValueError
rindex(sub[, start[, end]]) -> int
    #在指定的区间[start, end),从左至右,查找子串sub。找到返回索引,没找到抛出异常ValueError
count(sub[, start[, end]]) -> int
    #在指定的区间[start, end),从左至右,统计子串sub出现的次数
len(string)    #返回字符串的长度,即字符的个数
时间复杂度:index和count方法都是O(n),随着列表数据规模的增大,而效率下降


字符串判断***    #返回值为布尔型
    #endswith(suffix[, start[, end]]) -> bool
        #在指定的区间[start, end),字符串是否是suffix结尾
    #startswith(prefix[, start[, end]]) -> bool
        #在指定的区间[start, end),字符串是否是prefix开头
字符串判断 is系列
isalnum() -> bool 是否是字母和数字组成
isalpha() 是否是字母
isdecimal() 是否只包含十进制数字
isdigit() 是否全部数字(0~9)
isidentifier() 是不是字母和下划线开头,其他都是字母、数字、下划线
islower() 是否都是小写
isupper() 是否全部大写
isspace() 是否只包含空白字符

字符串格式化(c风格比较杂乱需要记得比较多)
字符串的格式化是一种拼接字符串输出样式的手段,更灵活方便
    #join拼接只能使用分隔符,且要求被拼接的是可迭代对象
    #+ 拼接字符串还算方便,但是非字符串需要先转换为**字符串**才能拼接
在2.5版本之前,只能使用printf style风格的print输出
    #printf-style formatting,来自于C语言的printf函数
    格式要求
    #占位符:使用%和格式字符组成,例如%s、%d等
        #s调用str(),r会调用repr()。所有对象都可以被这两个转换。
    #占位符中还可以插入修饰字符,例如%03d表示打印3个位置,不够前面补零
    #format % values,格式字符串和被格式的值之间使用%分隔
    #values只能是一个对象,或是一个和格式字符串占位符数目相等的元组,或一个字典


字符串格式化***(运用format()函数格式化,python推荐版本)
*format函数格式字符串语法——Python鼓励使用*
    #"{} {xxx}".format(*args, **kwargs) -> str
    #args是位置参数,是一个元组
    #kwargs是关键字参数,是一个字典
    #花括号表示占位符
    #{}表示按照顺序匹配位置参数,{n}表示取位置参数索引为n的值
    #{xxx}表示在关键字参数中搜索名称一致的
    #{{}} 表示打印花括号
    #位置参数
        "{}:{}".format(‘192.168.1.100‘,8888),这就是按照位置顺序用位置参数替换前面的格式字符串的占位符中
    #关键字参数或命名参数
        "{server} {1}:{0}".format(8888, ‘192.168.1.100‘, server=‘Web Server Info : ‘) ,位置参数按照序号匹配,
    #关键字参数按照名词匹配
?         #访问元素
            "{0[0]}.{0[1]}".format((‘magedu‘,‘com‘))
        #对象属性访问
            from collections import namedtuple
            Point = namedtuple(‘Point‘,‘x y‘)
            p = Point(4,5)
            "{{{0.x},{0.y}}}".format(p)

        #对齐
            ‘{0}*{1}={2:<2}‘.format(3,2,2*3)    #冒号前面是索引号
            ‘{0}*{1}={2:<02}‘.format(3,2,2*3)    #可以写成{:0<3}.format(6),对齐空的位置补0,0可以换成其他字符也支持
            ‘{0}*{1}={2:>02}‘.format(3,2,2*3)    #与上一个相反
            ‘{:^30}‘.format(‘centered‘)        #代表中间对齐
            ‘{:*^30}‘.format(‘centered‘)        #中间对齐0补空白位置
        #进制
            "int: {0:d}; hex: {0:x}; oct: {0:o}; bin: {0:b}".format(42)    #0是索引号,d十进制,x十六进制,o八进制,b二进制
            "int: {0:d}; hex: {0:#x}; oct: {0:#o}; bin: {0:#b}".format(42)    #前面加成ox...
            把下面的数转换输出:
            octets = [192, 168, 0, 1]
            ‘{:02X}{:02X}{:02X}{:02X}‘.format(*octets)        #*octets,是把上面的列表解开放到format里转换成16进制
        #浮点数
            print("{}".format(3**0.5))  # 1.7320508075688772
            print("{:g}".format(3**0.5))  # 1.73205
            print("{:f}".format(3**0.5))  # 1.732051
            print("{:10f}".format(3**0.5))  # 右对齐#
            print("{:2}".format(102.231))  # 宽度为2
            print(“{:.2}”.format(3**0.5))  # 1.7 2个数字
            print("{:.2f}".format(3**0.5))  # 1.73 小数点后2位
            print("{:3.2f}".format(3**0.5))  # 1.73 宽度为3,小数点后2位
            print("{:3.3f}".format(0.2745)) # 0.275    #%3    控制宽度
            print("{:3.3%}".format(1/3))  # 33.333%    #%.3    控制精度

python学习随笔(三)_字符串

标签:pre   效率   排版   精度   需要   表示   三元   magedu   ***   

原文地址:https://www.cnblogs.com/springquanquan/p/9460126.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!