Python基础笔记
来源:互联网 发布:下载php文件怎么打开 编辑:程序博客网 时间:2024/06/03 04:26
>>> print 'Bob said \"I\'m OK\".'
如果一个字符串包含很多需要转义的字符,对每一个字符都进行转义会很麻烦。为了避免这种情况,我们可以在字符串前面加个前缀r
,表示这是一个 raw 字符串,里面的字符就不需要转义了。例如:
print r'\(~_~)/ \(~_~)/'
但是r'...'
表示法不能表示多行字符串,也不能表示包含'
和 "
的字符串(为什么?)
如果要表示多行字符串,可以用'''...'''
表示:
'''Line 1Line 2Line 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 = Trueprint 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同学,以及后面的所有同学,都自动向后移动一位。
Python从list删除元素
Python中替换元素
Python之创建tuple
Python之创建单元素tuple
Python之“可变”的tuple
Python之if语句
Python之 for循环
Python之什么是dict
Python之 访问set
Python之定义可变参数
对应上面的问题,取前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),'------>', Lfor 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.0for v in d.itervalues(): sum = sum + vprint 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.0for k, v in d.iteritems(): sum = sum + v print k, ':', vprint 'average', ':', sum / len(d)Lisa : 85Paul : 74Adam : 95Bart : 59average : 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)
- [Python] Python基础笔记
- Python基础笔记摘要
- Python 笔记 : 基础
- Python基础学习笔记
- [笔记]Python对象基础
- python 基础笔记
- Python基础笔记
- Python 基础笔记(1)
- Python 基础笔记(2)
- python基础笔记
- Python基础笔记
- python基础笔记1
- python基础笔记(一)
- python基础学习笔记
- Python基础学习笔记
- Python基础笔记
- Python基础语法笔记
- python基础笔记
- 个人初学laravel笔记记录
- 【Android】安卓平台上Javascript和Java的交互
- 百练_2696:计算表达式的值
- Arrays sort实现
- 项目模块化构建记录
- Python基础笔记
- linux如何查看所有的用户和组信息?
- layui原生表单验证
- 小程序的循环
- 重写magento的model, block 和controller
- 05-POSTFIX邮件服务
- Unity鼠标悬停实现图片的浮动效果
- 机器学习--k-近邻(kNN)算法
- 《java编程思想》P22-P37(第二章一切都是对象)