python学习笔记——字符串
类方法string.upper(str)需要引入string模块,实例方法str.upper()不需要引入string模块
无与伦比的列表解析功能
# coding=utf-8# 列表解析print [i * 2 for i in [8, -2, 5]]print [i for i in range(8) if i % 2 == 0] |
在FF的javascript1.7就实现了相同的语法( Array Comprehension)
var evens = [i for (i in range(0, 21)) if (i % 2 == 0)]; |
字符串模板
# coding=utf-8# 字符串模板from string import Templates = Template('There are ${howmany} ${lang} Quotation Symbols')print s.substitute(lang='python',howmany=3) |
这东西,javascrit也有,如著名的Prototype就有这个Template类,不同的是它的替换函籽叫做evaluate,而不是 substitute,mootools有这个同名方法,但却是直接内置到String原生对象上,kissy框架则是这样用 KISSY.substitute(str, o),qwrap框架经过retouch后,可以这样用'{0} love {1}'.format('I','You'),而我的框架dom.format则支持两个传参方式:
var a = dom.format("Result is #{0},#{1}", 22,33); alert(a);//"Result is 22,33" var b = dom.format("#{name} is a #{sex}",{name:"Jhon",sex:"man"}); alert(b);//"Jhon is a man" |
原始字符串操作符(r/R),能方便处理反斜杠:
f = open(r'C:\Program Files\Adobe\Reader 9.0\Setup Files\{AC76BA86-7AD7-2052-7B44-A94000000001}\setup.ini','r')for i in f: print if.close() |
同时遍历索引与值,以前我们使用for是这样实现的:
for i in range (0,len(list)): print i ,list[i] |
现在我们可以使用enumerate方法,更简洁:
for index,text in enumerate(list)): print index ,text |
对于javascript,想同时处理值与索引,我们可以使用javascript1.7的forEach迭代器,它直接在回调函数传入元素与索引与数组本身.
我想其内部的实现大概也是如此
def enumerate(collection): 'Generates an indexed series: (0,coll[0]), (1,coll[1]) ...' i = 0 it = iter(collection) while 1: yield (i, it.next()) i += 1 |
| 类型 | 方法 | 注解 |
|---|---|---|
| 填充 | center(width[, fillchar]), ljust(width[, fillchar]), rjust(width[, fillchar]), zfill(width), expandtabs([tabsize]) |
|
| 删减 |
strip([chars]), lstrip([chars]), rstrip([chars]) |
chars为指定要去掉的字符,默认为空白字符,它由string.whitespace常量定义 |
| 变形 |
lower(),#全部小写 upper(),#全部小写 capitalize(),#首字母大写 swapcase(),#大小写交换 title()#每个单词第一个大写,其他小写 |
因为title() 函数并不去除字符串两端的空白符也不会把连续的空白符替换为一个空格, 所以建议使用string 模块中的capwords(s)函数,它能够去除两端的空白符,再将连续的空白符用一个空格代替。 >>> ' hello world!'.title() |
| 切割 | partition(sep), rpartition(sep), splitlines([keepends]), split([sep [,maxsplit]]), rsplit([sep[,maxsplit]]) |
|
| 连接 | join(seq) | join() 函数的高效率(相对于循环相加而言),使它成为最值得关注的字符串方法之一。 它的功用是将可迭代的字符串序列连接成一条长字符串,如: >>> conf = {'host':'127.0.0.1',
|
| 判定 | isalnum(), isalpha(), isdigit(), islower(), isupper(), isspace(), istitle(), startswith(prefix[, start[, end]]), endswith(suffix[,start[, end]]) |
这些函数都比较简单,顾名知义。需要注意的是*with()函数族可以接受可选的 start, end 参数,善加利用,可以优化性能。 另,自 Py2.5 版本起,*with() 函数族的 prefix 参数可以接受 tuple 类型的实参,当实参中的某人元素能够匹配,即返回 True。 |
| 查找 |
count( sub[, start[, end]]), find( sub[, start[, end]]), index( sub[, start[, end]]), rfind( sub[, start[,end]]), rindex( sub[, start[, end]]) |
find()函数族找不到时返回-1,index()函数族则抛出ValueError异常。 另,也可以用 in 和 not in 操作符来判断字符串中是否存在某个模板。 |
| 替换 |
replace(old, new[,count]), translate(table[,deletechars]) |
replace()函数的 count 参数用以指定最大替换次数 translate() 的参数 table 可以由 string.maketrans(frm, to) 生成 translate() 对 unicode 对象的支持并不完备,建议不要使用。 |
| 编码 |
encode([encoding[,errors]]), decode([encoding[,errors]]) |
这是一对互逆操作的方法,用以编码和解码字符串。因为str是平台相关的,它使用的内码依赖于操作系统环境, 而unicode是平台无关的,是Python内部的字符串存储方式。 unicode可以通过编码(encode)成为特定编码的str,而str也可以通过解码(decode)成为unicode。 |
python学习笔记——字符串的更多相关文章
- Python学习笔记-字符串
Python之使用字符串 1.所有的标准序列操作(索引,分片,乘法,判断成员资格,求长度,取最小值,最大值)对字符串同样适用.但是字符串都是不可变的. 2.字符串格式化使用字符串格式化操作符即%. f ...
- Python学习笔记 - 字符串和编码
#!/usr/bin/env python3 # -*- coding: utf-8 -*- #第一行注释是为了告诉Linux/OS X系统, #这是一个Python可执行程序,Windows系统会忽 ...
- python 学习笔记 字符串和编码
字符编码:因为计算机只能处理数字,如果要处理文本,就必须先把文本转换为数字才能处理,最早的计算机在设计时采用8个比特(bit)作为一个字节 (byte),所以,一个字节能表示的最大的整数是255(二进 ...
- Python学习笔记-字符串与注释
OSX从Pthon 2.7升级到3.8 1,官网下载最新安装包安装 2,执行认证文件command 3,执行设置path command 4,设置默认python 在terminal里运行open ...
- python学习笔记-字符串的拼接
1.百分号方式拼接 %[(name)][flags][width].[precision]typecode (name) 可选,用于选择指定的key flags 可选,可供 ...
- [Python学习笔记] 字符串类型及操作
字符串处理 索引:返回字符串中单个字符 <字符串>[M] 切片:返回字符串中一段字符子串 <字符串>[M:N:K] 字符串格式化使用.format()方法
- python学习笔记--字符串格式化
字符串和常量 print(r'hello\py\thon') r 代表后面字符不进行转义,原样输出; 表示常量,命名时变量名字大写代表常量.NAME = 'liulixue'; 字符串表示:' ', ...
- 【python学习笔记】3.字符串使用
[python学习笔记]3.字符串使用 字符串是一种序列,素有标准的序列操作对字符串用样适用,字符串是不可以改变 格式化操作符,%,左侧是格式化字符串,右侧是被格式的值,可以是一个值.元组.字典 数值 ...
- python学习笔记(二)、字符串操作
该一系列python学习笔记都是根据<Python基础教程(第3版)>内容所记录整理的 1.字符串基本操作 所有标准序列操作(索引.切片.乘法.成员资格检查.长度.最小值和最大值)都适用于 ...
随机推荐
- java ssm框架入门(二)添加语言滤器
使用过滤器是在web.xml中使用filter,以下是码过滤器,过滤所有资源的使用 web.xml <filter> <filter-name>setCharactor< ...
- 性能加速 - 开启opcache
说明 PHP 5.5+版本以上的,可以使用PHP自带的opcache开启性能加速(默认是关闭的).对于PHP 5.5以下版本的,需要使用APC加速,这里不说明,可以自行上网搜索PHP APC加速的方法 ...
- 树形dp - Codeforces Round #322 (Div. 2) F Zublicanes and Mumocrates
Zublicanes and Mumocrates Problem's Link Mean: 给定一个无向图,需要把这个图分成两部分,使得两部分中边数为1的结点数量相等,最少需要去掉多少条边. ana ...
- Generator生成器函数
接触过Ajax请求的会遇到过异步调用的问题,为了保证调用顺序的正确性,一般我们会在回调函数中调用,也有用到一些新的解决方案如Promise相关的技术. 在异步编程中,还有一种常用的解决方案,它就是Ge ...
- 敏捷软件开发实践-Sprint Retrospective Meeting(转)
介绍: 在敏捷开发模式中,Sprint Retrospective Meeting 也是一个必不可少的环节,它通常发生在每个Sprint的结尾,其主要作用是对于当前的迭代周期做一个阶段性的总结,包括好 ...
- 【BZOJ】1009: [HNOI2008]GT考试(dp+矩阵乘法+kmp+神题)
http://www.lydsy.com/JudgeOnline/problem.php?id=1009 好神的题orzzzzzzzzzz 首先我是连递推方程都想不出的人...一直想用组合来搞..看来 ...
- Loadrunner测试实例分析
LoadRunner性能测试结果分析是个复杂的过程,通常可以从结果摘要.并发数.平均事务响应时间.每秒点击数.业务成功率.系统资源.网页细分图.Web服务器资源.数据库服务器资源等几个方面分析,如图1 ...
- linux配置防火墙打开3306端口
安装完MYSQL服务器后在本机所有操作都正常, 但在其它机器上远程访问这个MYSQL服务器时怎么都连接不上. shit! 怀疑是端口问题, 结果: telnet 192.168.1.245 33 ...
- 深入分析jquery解析json数据
我们先以解析上例中的comments对象的JSON数据为例,然后再小结jQuery中解析JSON数据的方法. JSON数据如下,是一个嵌套JSON: {"comments":[{& ...
- unity导弹算法 预计目标点
关于导弹的飞行算法,网上有很多教程.简单算法无非是获取目标点的当前位置,然后导弹朝目标方向移动.高深点的,就是通过计算获取碰撞点然后朝着目标移动.如果你能看懂这个高深算法的话,可以去看原帖:http: ...