字符串是任何计算机语言中最常见的数据类型,python中也不例外,因此熟练掌握字符串是学习python的必备技能。
python中字符串三种定义方式

str = 'wang'
str = "wang"
str = """wang"""

字符串所有方法如下:

['capitalize', 'casefold', 'center', 'count', 'encode', 'endswith',
'expandtabs', 'find', 'format', 'format_map', 'index', 'isalnum',
'isalpha', 'isdecimal', 'isdigit', 'isidentifier', 'islower', 'isnumeric',
'isprintable', 'isspace', 'istitle', 'isupper', 'join', 'ljust', 'lower',
'lstrip', 'maketrans', 'partition', 'replace', 'rfind', 'rindex', 'rjust',
'rpartition', 'rsplit', 'rstrip', 'split', 'splitlines', 'startswith',
'strip', 'swapcase', 'title', 'translate', 'upper', 'zfill']

字符串常见的操作,需要熟练掌握
1、按照索引取值,正向取、反向取
2、切片(切片操作顾头不顾尾,可以按照步长进行切片)
3、长度len (str)
4、成员运算 in  not in
5、移除空白strip
6、切分split
7、循环

1、按照索引取值,正向取、反向取(索引每次只能取一个元素)

str1 = 'wang'
#正向取出索引为1的字符
print(str1[1])
#反向取出索引为-1的字符,即最后一个字符
print(str1[-1])

2、切片(切片操作顾头不顾尾,可以按照步长进行切片)可以取多个元素

str2='wangchengliang'
#正向取切片取出出索引为0到1的字符,[0:2]不含2
print(str2[0:2])

3、长度len (str3)

str3='wang'
#len(str3)获取str3的长度
print(len(str3))

4、成员运算 in  not in

str4 = 'wangw'
#判断'wa','q'是否是str4的成员
print('wa'in str4)
print('q' not in str4)

5、移除空格strip,lstrip去掉左边空格, rstrip去掉右边空格

#将字符串两端空格移除,返回字符串'wang5'
str5=' wang5 '
print(str5.strip())
#将字符串两端'#'移除,返回字符串'wang5'
str5_1='##wang5##'
print(str5_1.strip('#'))

6、切分split

str6="12343242354361254368634"
#以2位切割符,切割字符串str2,并返回一个列表
print(str6.split('2')) name='root:x:0:0::/root:/bin/bash'
#默认分隔符为空格
print(name.split(':'))
name='C:/a/b/c/d.txt'
#只想拿到顶级目录
print(name.split('/',1))

 7、循环

str7='wang'
for i in str7:
print(i)

常见方法
strip lstrip rstrip
lower upper
startswith endswiht
format 三种玩法
split rsplit
replace
isdigit

capitalize
将字符串首字母变成大写

name = 'my \tname is wanganchengliang'
print(name.capitalize())

count
统计字符串中某个字符出现的次数或某个子字符串出现的次数

name = 'my \tname is wanganchengliang'
print(name.count('an'))

center
打印50个字符,不够50个,用-补充,并把字符串放在中间

name = 'my \tname is wanganchengliang'
print(name.center(50,"-"))

encode
把字符串转换成二进制

name = 'my \tname is wanganchengliang'
print(name.encode())

endswith
判断字符串以什么结尾

name = 'my \tname is wanganchengliang'
print(name.endswith("ng"))
str1 = '#swangchengliang'
#判断是否以'#'开头
print(str1.startswith('#'))

expandtabs
将字符串中已有的空格扩大多少倍

name = 'my \tname is wanganchengliang'
print(name.expandtabs(tabsize=20))

find
返回字符串中子符或子字符串的索引位置

name = 'my \tname is wanganchengliang'
print(name.find("name"))

format
格式化字符串输出

name1="my name is {name} and I am {years} old"
print(name1.format(name='wang',years=22))

format_map
字典方式格式化字符串输出

print(name1.format_map({'name':'wang','years':22}))

isalnum
确认字符串中是纯英文字符,真返回True

print("123abc".isalnum())

isalpha
确认字符串中是否包含阿拉伯数字和字符,真返回True

print("abc".isalpha())

isdecimal
是否是十进制

print("123".isdecimal())

isdigit
是否是一个整数

print("123".isdigit())

isidentifier
判断是否是一个合法的变量名

print("a23".isidentifier())

islower
判断字母是否都小写

print("Aa123".islower())

isupper
判断字母是否都大写

print("Aa123".isupper())

isnumeric
判断是否是只有数字

print("123".isnumeric())

isspace
判断是否是空格

print(" 123".isspace())

istitle
判断每个子字符是否是大写

print("My Name Is".istitle())

isprintable
是否可以打印,linux中终端设备文件不可以打印,返回假

print("123".isprintable())

join
字符串拼接join,该方法很重要

#将列表中元素拼接在一起,可以在中间指定特定字符串
print( ','.join(['1','2','3']))
name = ' '
print(name.join(['wang','cheng','liang'])) #可迭代对象必须都是字符串
#将列表中各个元素通过__连接成字符串
name1 = ['wang','cheng','liang']
newname='__'.join(name1)
print(newname)

ljust
打印字符串长度为50 不够再后面以指定字符填充

print("My Name Is".ljust(50,'w'))

rjust
打印字符串长度为50 不够再前面以指定字符填充

print("My Name Is".rjust(50,'w'))

upper
小写变大写

print("abc".upper())

lower
大写变小写

print("ABCD".lower())

lstrip
去掉左边的回车或空格

print("  \nerf".lstrip())

rstrip
去掉右边的回车或空格

print("fgh\n  ".rstrip())

strip
去掉左右两边的空格和回车

print("  \ntt\n   ".strip())

translate
加密字符串

p = str.maketrans('qwert','12345')
print("wanger".translate(p))
print(p)

replace

字符串中子字符替换

#替换指定的字符或字符串
print("abc".replace('a','1'))
name='wangchengliang'
#替换所有位置ng为'王'
print(name.replace('ng','王'))
#替换第一次出现的'ng'为王
print(name.replace('ng','王',1))

rfind
找到最右边的字符或字符串的下标

print("qweer12".rfind('e'))

split
按照指定的条件分割形成列表

print("qwew qe13".split(' '))
print("qwewqe13".split('e'))
print("1+2+3+4+5+6".split('+'))

splitlines
按照换行符分割成列表

print("1234\nwerew".splitlines())

startswith

判断字符串是否以某个子字符或字符串开头

str1 = '#swangchengliang'
#判断是否以#开头
print(str1.startswith('#'))

swapcase
大写变小写 小写变大写

print("qeeWwW".swapcase())

zfill
输出指定的字符串,不够以0填充

print("weqwe".zfill(10))

补充:

输出自己名字的二进制、十进制、十六进制
说明:
python3.5中,for循环字符串时,循环的每一个元素是字符

utf-8中一个字符等于3个字节
gbk 中一个字符等于3个字节
字符--->字节转换方式(bytes to str  str to bytes)

name="王成亮"
byte_list= bytes(name,encoding='utf-8')

将字符串转换成字节

b1 =bytes(name,encoding='utf-8')
b2 =bytes(name,encoding='gbk')
print(b1)
print(b2)

 将字节转换成字符串

b3 = str(b1,encoding='utf-8')
b4 = str(b2,encoding='gbk')
print(b3)
print(b4)

将名字的二进制,十进制,十六进制方式输出

name = "王成亮"
for n in name:
#utf-8中一个汉字3个字节,默认打印每个汉字
print(n)
#将字符转换为byte类型,输出16进制
byte_list_n= bytes(n,encoding='utf-8')
print(byte_list_n)
#循环字符类型输出十进制,使用bin()方法输出二进制
for b in byte_list_n:
print(b,bin(b))

3、python数据类型之字符串(str)的更多相关文章

  1. python数据类型之字符串(str)和其常用方法

    字符串是有序的,不可变的. 下面的例子说明了字符串是不可变的 name = 'alex' name = 'Jack' """ 并没有变,只是给name开启了一块新内存,储 ...

  2. Python基本数据类型之字符串str

    字符串 定义:它是一个有序的字符的集合,用于存储和表示基本的文本信息,‘’或“”或‘’‘ ’‘’中间包含的内容称之为字符串 字符串的结构类型为'...' "..." "' ...

  3. Python数据类型之字符串

    一:概述 Python中的字符串的一些概念 可以看作是字符的集合,在数据类型里没有单个字符的数据类型,可以用单个字符表示的一个字符串数据类型 字符串是一种不可变的序列类型,单个字符从左到右按照顺序排列 ...

  4. Python数据类型-02.字符串

    本文主要记录字符串的相关知识,包括字符串的定义特点,常用方法和 请知悉: 计算机中,一切皆为对象世界万物,皆为对象,一切对象皆可分类 1.什么是字符串? 类似"hello world&quo ...

  5. Python数据类型(字符串)

    文章内容参考了教程:http://www.runoob.com/python/python-basic-syntax.html#commentform Python 字符串 字符串是 Python 中 ...

  6. python基础【2】——python数据类型之字符串

    python数据类型-字符串 一. 字符串的表示方法(str) 作用: 记录文本信息 表示方法:' ' 单引号 " "双引号 ''' '''三单引号 ""&qu ...

  7. Python笔记_第一篇_面向过程_第一部分_5.Python数据类型之字符串类型(string)

    关于Python的字符串处理也如其他语言一样属于重点中的重点,主要是牵扯到的函数和内容较为多和乱一些.关于什么是字符串,Python中的定义是:以单引号或者双引号括起来的任意文本. 1.   字符串的 ...

  8. Python数据类型之字符串类型

    字符串的表示 字符串是Python中最常用的数据类型之一,必须使用成对的引号包围来表示字符串,引号可以是单引号 ' .双引号 " .三引号''' """,格式如 ...

  9. python数据类型:序列(字符串,元组,列表,字典)

    序列通常有2个特点: 1,可以根据索引取值 2,可以切片操作 字符串,元组,列表,字典,都可以看做是序列类型 我的操作环境:Ubuntu16.04+python2.7 一.字符串类型 >按索引获 ...

随机推荐

  1. [原]NYOJ-组合数-32

    大学生程序代写 http://acm.nyist.net/JudgeOnline/problem.php?pid=32 /*组合数 时间限制:3000 ms  |  内存限制:65535 KB 难度: ...

  2. 如何使 vlc 支持 fdk-aac 编码(windows平台

    可能是由于fdk-aac开源协议的原因,VLC默认是不支持fdk-aac编码的,fdk-aac 是非常优秀的AAC编码库,并且支持AAC-LD AAC-ELD, 对于要求低延迟的场景下很有用. 可以通 ...

  3. AtCoder Grand Contest 014 题解

    A - Cookie Exchanges 模拟 Problem Statement Takahashi, Aoki and Snuke love cookies. They have A, B and ...

  4. UOJ #348 州区划分 —— 状压DP+子集卷积

    题目:http://uoj.ac/problem/348 一开始可以 3^n 子集DP,枚举一种状态的最后一个集合是什么来转移: 设 \( f[s] \) 表示 \( s \) 集合内的点都划分好了, ...

  5. Poj2656(水题)

    一.Description Jinjin is a junior school student. Besides the classes in school, Jinjin's mother also ...

  6. flume+kafka+storm+mysql架构设计

    前段时间学习了storm,最近刚开blog,就把这些资料放上来供大家参考. 这个框架用的组件基本都是最新稳定版本,flume-ng1.4+kafka0.8+storm0.9+mysql (项目是mav ...

  7. js之翻牌游戏中的一个深刻感悟

    先“上菜”: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UT ...

  8. openstack常见问题汇总

    汇总下常见的问题以及解释下一些比较容易让人萌的参数配置等等 问题汇总1.使用纯文本模式进行复制粘贴,打死不要用word!!!可以解决绝大多数问题,如果你依然执迷不悟,那么就好自为之吧 2.创建路由器时 ...

  9. 初识Luajit

    转自:http://www.cppblog.com/pwq1989/archive/2013/11/28/204487.html 大家可以从官网下载到源码(http://luajit.org/),也可 ...

  10. Nmon工具的使用以及通过nmon_analyse生成分析报表

    在我们监控我们的操作系统的时候如果可以把各个硬件的监控信息生成形象化的分析报表图对于我们来说是件太好的事情了,而通过ibm的nom和nmon_analyser两者的结合完全可以实现我们的要求.首先对n ...