注:以下内容全部为 廖雪峰的官方网站 中学习内容的摘要和总结
输入和输出:
name = raw_input('please enter your name: ')
print '100 + 200 =', 100 + 200
数据类型和变量:
变量本身类型不固定的语言称之为动态语言,Python是动态语言。
字符串和编码:
1.ASCII(不全)、Unicode(全,但定长所以占用空间大)和UTF-8(全,变长) 。
2.普通的字符串'ABC'
在Python内部都是ASCII编码,Python后来添加了对Unicode的支持,以Unicode表示的字符串用u'...'
表示。
print u'中文'
3.由于Python源代码也是一个文本文件,所以,当源代码中含中文时,保存源代码时,需指定保存为UTF-8编码。当Python解释器读取源代码时,为了让它按UTF-8编码读取,我们通常在文件开头写上这两行:
#!/usr/bin/env python # -*- coding: utf-8 -*-
第一行注释是为了告诉Linux/OS X系统,这是一个Python可执行程序,Windows系统会忽略这个注释;
第二行注释是为了告诉Python解释器,按照UTF-8编码读取源代码,否则,你在源代码中写的中文输出可能会有乱码。
(申明了UTF-8编码并不意味着你的.py
文件就是UTF-8编码的)必须要确保Notepad++正在使用UTF-8 without BOM编码,在encoding目录下选择该项。
4.关于格式化,采用如下占位符及形式:
'Hi, %s, you have $%d.' % ('Michael', 1000000)
使用list和tuple:
列表数据类型:list。list是一种有序的集合,可以随时添加和删除其中的元素。
>>> classmates = ['Michael', 'Bob', 'Tracy'] >>> classmates ['Michael', 'Bob', 'Tracy']
list其他操作见廖雪峰官网。
另一种有序列表叫元组:tuple。tuple和list非常类似,但是tuple一旦初始化就不能修改,
>>> t = (1, 2) >>> t (1, 2)
只有1个元素的tuple定义时必须加一个逗号,
,来消除歧义:
>>> t = (1,) >>> t (1,)
综上,list和tuple是Python内置的有序集合,一个可变,一个不可变。根据需要来选择使用它们,尽量使用tuple,更安全。
条件判断和循环:
条件判断:
age = 3 if age >= 18: print 'your age is', age print 'adult' else: print 'your age is', age print 'teenager'
age = 3 if age >= 18: print 'adult' elif age >= 6: print 'teenager' else: print 'kid'
for...in循环:
依次把list或tuple中的每个元素迭代出来。
for x in ...
循环就是把每个元素代入变量x
,然后执行缩进块的语句。
sum = 0 for x in [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]: sum = sum + x print sum
range(101)就可以生成0-100的整数序列
sum = 0 for x in range(101): sum = sum + x print sum
while循环:
sum = 0 n = 99 while n > 0: sum = sum + n n = n - 2 print sum
再议raw_input():
此输入自动设为字符串类型,若输入数字且需比较时,需先强制转换成int型等。
birth = int(raw_input('birth: '))
使用dict和set:
dict:
Python内置了字典:dict的支持,dict全称dictionary,在其他语言中也称为map,使用键-值(key-value)存储,具有极快的查找速度。
>>> d = {'Michael': 95, 'Bob': 75, 'Tracy': 85} >>> d['Michael'] 95
把数据放入dict的方法,除了初始化时指定外,还可以通过key放入:
>>> d['Adam'] = 67 >>> d['Adam'] 67
和list比较,dict有以下特点:
- 查找和插入的速度极快,不会随着key的增加而增加;
- 需要占用大量的内存。
dict可以用在需要高速查找的地方,dict的key必须是不可变对象。这是因为dict根据key来计算value的存储位置,如果每次计算相同的key得出的结果不同,那dict内部就完全混乱了。这个通过key计算位置的算法称为哈希算法(Hash)。
set:
set和dict类似,也是一组key的集合,但不存储value。由于key不能重复,所以,在set中,没有重复的key。
要创建一个set,需要提供一个list作为输入集合:
>>> s = set([1, 2, 3]) >>> s set([1, 2, 3])
set和dict的唯一区别仅在于没有存储对应的value(都无序),et同样不可以放入可变对象,因为无法判断两个可变对象是否相等。
再议不变对象:
对于不变对象来说,调用对象自身的任意方法,也不会改变该对象自身的内容。相反,这些方法会创建新的对象并返回,这样,就保证了不可变对象本身永远是不可变的。