原始字符串
使用\转义或者r,这种方法在网站设置网站目录结构的时候非常管用。
>>> dos="c:\news"
>>> print dos
c:
ews
>>> dos="c:\\news"
>>> print dos
c:\news
>>> dos=r"c:\news" #r开头的字符串就是原始字符串
>>> print dos
c:\news
>>>
索引和切片
第一个字符是排序为0,空格也占用一个位置
>>> lang="study python"
>>> lang[0]
's'
>>> lang[2]
'u'
>>> "hello"[0]
'h'
根据字符查索引
>>> lang.index("py") >>> lang="study python"
>>> lang.index("s") >>> lang.index("p") >>>
切片
得到的字符串是前包括后不包括(序号)
>>> lang="study python"
>>> lang[0:4] #从0到序号4之前的字符串
'stud'
>>> lang[1:] #从序号1到最末的字符串
'tudy python'
>>> lang[:10]
'study pyth' #得到序号10之前的字符,包括10
>>> lang[:] #得到所有字符
'study python'
还有一种就是从右边开始切,注意[]中左边的数字要小于右边的数字
>>> a="python"
>>> a[-1]
'n'
>>> a[-3:-1]
'ho'
字符串的连接
>>> str1="hello"
>>> str2="world"
>>> str1+" "+str2 #字符串的连接
'hello world'
判断一个字符串是否包含另一个字符串
>>> "h" in "hello"
True
>>> "lll" in "hello"
False
求最值
一个字符串中的每个字符在计算机中都对应着一个编码。
>>> max("hello")
'o'
>>> min("hello")
'e'
>>> max("","")
''
查看一个字符对应的ASCII值
>>> ord("a")
97
>>> ord("b")
98
>>> ord("A")
65
字符串的比较
小于则返回-1,等于返回0,大于返回1,注意字符串之间的比较,先比较第一个字符,如果相等就比第二个字符,如果不相等则返回比较结果。
>>> cmp("a","b")
-1
>>> cmp("","")
-1
>>> cmp("abc","b")
-1
字符串之间的乘法
>>> "-"*10
'----------'
>>> "a"*10
'aaaaaaaaaa'
计算一个字符串之间的长度
返回的是int类型
>>> m=len("hello")
>>> m
5
>>> type(m)
<type 'int'>
字符串格式化输出
>>> "I like %s ,you know." %"Python" %s是个占位符可以被其它字符串代替
'I like Python ,you know.'
>>> "%d years" %15
'15 years'
>>> "My wegiht is %.2f" %70.222
'My wegiht is 70.22'
>>> "My wegiht is %+.2f" %70.222
'My wegiht is +70.22'>>> print "My name is %s,I'm %d years." %("Keven",20) #也可以出现多个替代符
My name is Keven,I'm 20 years.
上面的方法常被认为是太古老的,下面是新的格式方法,即String .format的格式方法,{}作为占位符
>>> print "My name is {},I'm {} years.".format("Keven",20)
My name is Keven,I'm 20 years.
>>> print "My name is {name},I'm {age} years.".format(name="Keven",age=20) #如果觉得还不明确,可以采取这种对应的方法
My name is Keven,I'm 20 years.
常用的字符串方法
>>> dir(str)
['__add__', '__class__', '__contains__', '__delattr__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__', '__getitem__', '__getnewargs__', '__getslice__', '__gt__', '__hash__', '__init__', '__le__', '__len__', '__lt__', '__mod__', '__mul__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__rmod__', '__rmul__', '__setattr__', '__sizeof__', '__str__', '__subclasshook__', '_formatter_field_name_split', '_formatter_parser', 'capitalize', 'center', 'count', 'decode', 'encode', 'endswith', 'expandtabs', 'find', 'format', 'index', 'isalnum', 'isalpha', 'isdigit', 'islower', 'isspace', 'istitle', 'isupper', 'join', 'ljust', 'lower', 'lstrip', 'partition', 'replace', 'rfind', 'rindex', 'rjust', 'rpartition', 'rsplit', 'rstrip', 'split', 'splitlines', 'startswith', 'strip', 'swapcase', 'title', 'translate', 'upper', 'zfill']
具体的方法可以用help查看
>>> help(str.upper)
Help on method_descriptor: upper(...)
S.upper() -> string Return a copy of the string S converted to uppercase.
(END)
实例:
1.split,分割,string向list转换
>>> "I love Python".split(" ")
['I', 'love', 'Python']
>>> "www.qq.com".split(".")
['www', 'qq', 'com'] >>> line = "Hello.I am keven.Welcome you."
>>> line.split(".",1) #指定分割的范围
['Hello', 'I am keven.Welcome you.']
2.strip,lstrip,rstrip,去空格
>>> " hello ".strip()
'hello'
>>> " hello ".lstrip()
'hello '
>>> " hello ".rstrip()
' hello'
3.字符大小写转换
- S.upper() 变大写
- S.lower 变小写
- S.capitalize() 首字母大写
- S.isupper() 是否全是大写
- S.islower 是否全是小写
- S.istitle() 每个单词的第一个字母是否为大写
>>> "hello".upper()
'HELLO'
>>> "hello".istitle()
False
>>> "Hello".istitle()
True
>>> "Hello World".istitle()
True
>>> "Hello world".istitle()
False
join()连接字符串
>>> b= "www.qq.com".split(".")
>>> b
['www', 'qq', 'com']
>>> ".".join(b)
'www.qq.com'
>>> "/".join(b)
'www/qq/com'
Python避免中文乱码
1.在开头声明
#coding=utf-8
2.遇到字符(节)串,立刻转化为unicode,不要用str(),直接使用unicode()
>>> a=unicode('中',encoding='utf-8')
>>> a
u'\u4e2d'
>>> print a.encode('utf-8')
中
3.如果对文件操作,打开文件的时候,最好用 codecs.open,替代 open
import codecs
codecs.open('filename', encoding='utf8')
Python学习笔记3—字符串的更多相关文章
-
python学习笔记(字符串操作、字典操作、三级菜单实例)
字符串操作 name = "alex" print(name.capitalize()) #首字母大写 name = "my name is alex" pri ...
-
【Python学习笔记】字符串操作
字符串的表示 python中的字符串是一个常量,可以使用单引号'',双引号""或三引号""" """来创建一个字符串常量 ...
-
Python学习笔记(3)-字符串
创建字符串 一对单引号或双引号 >>> 'hello world' 'hello world' >>> "hello world" 'hello ...
-
Python学习笔记:字符串
字符串 字符串定义:字符串可以使用一对单引号.双引号或三引号来定义,即便是单个字符也会当做字符串来处理(Python中没有字符类型,单个字符也就是只有一个字符的字符串而已). 原始字符串:字符串中反斜 ...
-
python学习笔记(一)---字符串与列表
字符串的一些处理 字符串的大小写 name="lonmar hb" print(name.upper())#全大写 print(name.lower())#全小写 print(na ...
-
【Python学习笔记】字符串拼接方法(5种)总结
字符串的 5 种拼接方法: “+”号 “,”号 直接连接 格式化 多行字符串拼接 第一种:“+”号 print("Hello"+"Python") 打印结果: ...
-
python学习笔记(二)-字符串方法
python的字符串内建函数: #====================常用方法=============================name = 'besttest' new_name = n ...
-
Python学习笔记之字符串
一.字符串格式化 >>> format="Hello,%s. %s enough for ya?" >>> values=('World','H ...
-
Python学习笔记一--字符串的使用
一.基本操作 1. 合并字符串:“+” 2. 打印重复的字符串:"*" 3. 按位获取字符串中的字符:索引 4. 按位获取字符串中的子字符串:分片 5 ...
随机推荐
-
Beta阶段站立会议-01
组名:金州勇士 组长:尹良亮 组员:王汉斌.杜月.闫浩楠 代码地址: ssh:git@git.coding.net:handsomeman/examm.githttps://git.coding.ne ...
-
mm/makefile
## Makefile for the linux memory manager.## Note! Dependencies are done automagically by 'make dep', ...
-
ASP.NET定制简单的错误处理页面
通常Web应用程序在发布后,为了给用户一个友好界面和使用体验,都会在错误发生时跳转至一个自定义的错误页面,而不是ASP.net向用户暴露出来的详细的异常列表. 简单的错误处理页面可以通过web.con ...
-
Mybatis学习——传递Map型参数
Spring整合Mybatis调用 public boolean editItemSales(int i_id, int i_sales) { Map<String, Object> ma ...
-
【JS】打印Excel——ActiveX控件
function viewToExcel(){ var filepath = "f:\\PrinterExcel.xls"; var xlApp; var xlBook; var ...
-
[python]pep8编码规范
一 代码编排1 缩进.4个空格的缩进(编辑器都可以完成此功能),不使用Tap,更不能混合使用Tap和空格.2 每行最大长度79,换行可以使用反斜杠,最好使用圆括号.换行点要在操作符的后边敲回车.3 类 ...
-
Activity跳转时传递Bitmap对象的实现
前言 相信大家可能都了解Activity跳转时我们是能够传递參数的,比方使用Intent传递或者Bundle来传递,把当前Activity的一些信息传递给将要跳转到的新的Activity.可是不知道大 ...
-
第三十讲:Android之Animation(五)
天行健,君子以自强不息.--<周易·乾·象> 本讲内容:逐帧动画 Frame Animation 逐帧动画 Frame Animation就是说一帧一帧的连起来播放就变成了动画,和放电影的 ...
-
安装jar包到本地仓库和远程仓库
转载: https://blog.csdn.net/zengdongwen/article/details/81241198 如何部署到maven*仓库呢? https://blog.csdn.ne ...
-
apache-tomcat 部分中文.html .jsp 连接 404问题
修改文件到 自己的安装目录:\apache-tomcat-7.0.79\conf 添加 Connector URIEncoding="utf-8" <Connector ...