>>> print 'Bob said \"I\'m OK\".'
如果一个字符串包含很多需要转义的字符,对每一个字符都进行转义会很麻烦。为了避免这种情况,我们可以在字符串前面加个前缀r
,表示这是一个 raw 字符串,里面的字符就不需要转义了。例如:
print r'\(~_~)/ \(~_~)/'
但是r'...'
表示法不能表示多行字符串,也不能表示包含'
和 "
的字符串(为什么?)
如果要表示多行字符串,可以用'''...'''
表示:
'''Line 1
Line 2
Line 3'''
上面这个字符串的表示方法和下面的是完全一样的:
'Line 1\nLine 2\nLine 3'
还可以在多行字符串前面添加 r
,把这个多行字符串也变成一个raw字符串:
r'''Python is created by "Guido".
It is free and easy to learn.
Let's start learn Python in imooc!'''
换行:
>>> print u'中文\n日文\n韩文'
中文
日文
韩文
>>> print u'''第一行
第二行'''
a = True
print a and 'a=T' or 'a=F'
计算结果不是布尔类型,而是字符串 'a=T',这是为什么呢?
因为Python把0
、空字符串''
和None
看成 False,其他数值和非空字符串都看成 True,所以:
True and 'a=T' 计算结果是 'a=T'
继续计算 'a=T' or 'a=F' 计算结果还是 'a=T'
要解释上述结果,又涉及到 and 和 or 运算的一条重要法则:短路计算。
1. 在计算 a and b
时,如果 a 是 False,则根据与运算法则,整个结果必定为 False,因此返回 a;如果 a 是 True,则整个计算结果必定取决与 b,因此返回 b。
2. 在计算 a or b
时,如果 a 是 True,则根据或运算法则,整个计算结果必定为 True,因此返回 a;如果 a 是 False,则整个计算结果必定取决于 b,因此返回 b。
#coding=utf-8
a = 'python'
print 'hello,', a or 'world'
b = ''
print 'hello,', b or 'world'
#第一次打印时。因为a变量不为空,发生短路运算,打印python.
#第一次打印时。因为b变量为空,布尔表达式正常运算,根据or(或)后面的表达式觉得布尔表达式的运算结果,所以打印world.
>>> L = ['Adam', 'Lisa', 'Bart']
>>> print L[0]
Adam
Bart同学是最后一名,俗称倒数第一,所以,我们可以用 -1 这个索引来表示最后一个元素:
>>> print L[-1]
Bart
类似的,倒数第二用 -2 表示,倒数第三用 -3 表示,倒数第四用 -4 表示:
现在,班里有3名同学:
>>> L = ['Adam', 'Lisa', 'Bart']
今天,班里转来一名新同学 Paul,如何把新同学添加到现有的 list 中呢?
第一个办法是用 list 的 append()
方法,把新同学追加到 list 的末尾:
>>> L = ['Adam', 'Lisa', 'Bart']
>>> L.append('Paul')
>>> print L
['Adam', 'Lisa', 'Bart', 'Paul']
append()总是把新的元素添加到 list 的尾部。
如果 Paul 同学表示自己总是考满分,要求添加到第一的位置,怎么办?
方法是用list的 insert()
方法,它接受两个参数,第一个参数是索引号,第二个参数是待添加的新元素:
>>> L = ['Adam', 'Lisa', 'Bart']
>>> L.insert(0, 'Paul')
>>> print L
['Paul', 'Adam', 'Lisa', 'Bart']
L.insert(0, 'Paul') 的意思是,'Paul'将被添加到索引为 0 的位置上(也就是第一个),而原来索引为 0 的Adam同学,以及后面的所有同学,都自动向后移动一位。
对应上面的问题,取前3个元素,用一行代码就可以完成切片:
>>> L[0:3]
['Adam', 'Lisa', 'Bart']
L[0:3]表示,从索引0开始取,直到索引3为止,但不包括索引3。即索引0,1,2,正好是3个元素。
如果第一个索引是0,还可以省略:
>>> L[:3]
['Adam', 'Lisa', 'Bart']
也可以从索引1开始,取出2个元素出来:
>>> L[1:3]
['Lisa', 'Bart']
只用一个 : ,表示从头到尾:
>>> L[:]
['Adam', 'Lisa', 'Bart', 'Paul']
因此,L[:]实际上复制出了一个新list。
切片操作还可以指定第三个参数:
>>> L[::2]
['Adam', 'Bart']
要取出3, 6, 9可以用::3的操作,但是要确定起始索引。
参考代码:
L = range(1, 101)
print L[:10]
print L[2::3]
print L[4:50:5]
5的倍数可以用 ::5 取出,要确定起始索引。
参考代码:
L = range(1, 101)
print L[-10:]
print L[-46::5]
>>> 'ABCDEFG'[:3]
'ABC'
>>> 'ABCDEFG'[-3:]
'EFG'
>>> 'ABCDEFG'[::2]
'ACEG'
字符串有个方法 upper() 可以把字符变成大写字母:
>>> 'abc'.upper()
'ABC'
取除首字母外的字符串用[1:]
参考代码:
def firstCharUpper(s):
return s[0].upper() + s[1:]
print firstCharUpper('hello')
print firstCharUpper('sunday')
print firstCharUpper('september')
1. 有序集合:list,tuple,str和unicode;
2. 无序集合:set
请用for循环迭代数列 1-100 并打印出7的倍数。
用range(1, 101)可以创建数组。
参考代码:
for i in range(1, 101):
if i % 7 == 0:
print i
L = ['Adam', 'Lisa', 'Bart', 'Paul']
for index, name in enumerate(L):
print index, '-', name
输出如下---->
0 - Adam
1 - Lisa
2 - Bart
3 - Paul
L = ['Adam', 'Lisa', 'Bart', 'Paul']
print len(L)
print range(1, len(L)+1),'------>', L
for index, name in zip(range(1, len(L)+1), L):
print index, '-', name
输出如下----->
4
[1, 2, 3, 4] ------> ['Adam', 'Lisa', 'Bart', 'Paul']
1 - Adam
2 - Lisa
3 - Bart
4 - Paul
d = { 'Adam': 95, 'Lisa': 85, 'Bart': 59 }
print d.values()
# [85, 95, 59]
for v in d.values():
print v
# 85
# 95
# 59
给定一个dict:
d = { 'Adam': 95, 'Lisa': 85, 'Bart': 59, 'Paul': 74 }
请计算所有同学的平均分。
由于分数存储在dict的value,因此,需要迭代 values() 或 itervalues()。
参考代码:
d = { 'Adam': 95, 'Lisa': 85, 'Bart': 59, 'Paul': 74 }
sum = 0.0
for v in d.itervalues():
sum = sum + v
print sum / len(d)
d = { 'Adam': 95, 'Lisa': 85, 'Bart': 59 }
print d.items()
#[('Lisa', 85), ('Adam', 95), ('Bart', 59)]
d = { 'Adam': 95, 'Lisa': 85, 'Bart': 59, 'Paul': 74 }
sum = 0.0
for k, v in d.iteritems():
sum = sum + v
print k, ':', v
print 'average', ':', sum / len(d)
Lisa : 85
Paul : 74
Adam : 95
Bart : 59
average : 78.25
L = [] for x in range(1, 11): L.append(x * x) print L #[1, 4, 9, 16, 25, 36, 49, 64, 81, 100]
print [x * x for x in range(1, 11)] #[1, 4, 9, 16, 25, 36, 49, 64, 81, 100]
print range(1, 10, 2)
print [x * (x + 1) for x in range(1, 10, 2)]
#[1, 3, 5, 7, 9]
#[2, 12, 30, 56, 90]
print [x * x for x in range(1, 11) if x % 2 == 0]
#[4, 16, 36, 64, 100]
1. isinstance(x, str) 可以判断变量 x 是否是字符串;
2. 字符串的 upper() 方法可以返回大写的字母。
请编写一个函数,它接受一个 list,然后把list中的所有字符串变成大写后返回,非字符串元素将被忽略。
提示:
1. isinstance(x, str) 可以判断变量 x 是否是字符串;
2. 字符串的 upper() 方法可以返回大写的字母。
利用 if 剔除掉非字符串的元素。
参考代码:
def toUppers(L):
return [x.upper() for x in L if isinstance(x, str)]
print toUppers(['Hello', 'world', 101])
print [m + n for m in 'ABC' for n in '123']
#['A1', 'A2', 'A3', 'B1', 'B2', 'B3', 'C1', 'C2', 'C3']
就等于下面这样子----->
L = []
for m in 'ABC':
for n in '123':
L.append(m + n)