Python快速学习

变量定义为动态变量,不需要设定类型
Python区分大小写 布尔值为True False
字符串 raw代表多行 例如 print ''' ...'''

数组操作
list操作 增加为 append insert(key,value) 删除操作使用pop总是删除最后一个

>>> t = ['Adam', 'Lisa', 'Bart']

Python之创建tuple tuple是另一种有序的列表,中文翻译为“ 元组 ”。tuple 和 list 非常类似,但是,tuple一旦创建完毕,就不能修改了。
同样是表示班里同学的名称,用tuple表示如下:

>>> t = ('Adam', 'Lisa', 'Bart')

创建tuple和创建list唯一不同之处是用( )替代了[ ]。

t = ('a', 'b', ['A', 'B'])list包含在tuple中是可变的

注意: Python代码的缩进规则。

具有相同缩进的代码被视为代码块,上面的3,4行 print 语句就构成一个代码块(但不包括第5行的print)。如果 if 语句判断为 True,就会执行这个代码块。

缩进请严格按照Python的习惯写法:4个空格,不要使用Tab,更不要混合Tab和空格,否则很容易造成因为缩进引起的语法错误。

注意: if 语句后接表达式,然后用:表示代码块开始。

如果你在Python交互环境下敲代码,还要特别留意缩进,并且退出缩进需要多敲一行回车:

>>> age = 20
>>> if age >= 18:
...     print 'your age is', age
...     print 'adult'
...
your age is 20
adult

Python的 for 循环就可以依次把list或tuple的每个元素迭代出来:

L = ['Adam', 'Lisa', 'Bart']
for name in L:
    print name

Python之什么是dict

  • dict的第一个特点是查找速度快,无论dict有10个元素还是10万个元素,查找速度都一样。
  • dict的第二个特点就是存储的key-value序对是没有顺序的!
  • dict的第三个特点是作为 key 的元素必须不可变

Python的 dict 就是专门干这件事的。用 dict 表示“名字”-“成绩”的查找表如下:

d = {
    'Adam': 95,
    'Lisa': 85,
    'Bart': 59
}```
我们把名字称为key,对应的成绩称为value,dict就是通过 key 来查找 value。注意: 通过 key 访问 dict 的value,只要 key 存在,dict就返回对应的value。如果key不存在,会直接报错:KeyError。

#要避免 KeyError 发生,有两个办法:

一是先判断一下 key 是否存在,用 in 操作符:

if 'Paul' in d:
print d['Paul']

如果 'Paul' 不存在,if语句判断为False,自然不会执行 print d['Paul'] ,从而避免了错误。

二是使用dict本身提供的一个 get 方法,在Key不存在的时候,返回None:

print d.get('Bart')
59
print d.get('Paul')
None


set 持有一系列元素,这一点和 list 很像,但是set的元素没有重复,而且是无序的,这点和 dict 的 key很像。
- set的内部结构和dict很像,唯一区别是不存储value,因此,判断一个元素是否在set中速度很快。

- set存储的元素和dict的key类似,必须是不变对象,因此,任何可变对象是不能放入set中的。
创建 set 的方式是调用 set() 并传入一个 list,list的元素将作为set的元素:

s = set(['A', 'B', 'C'])```
请注意,上述打印的形式类似 list, 但它不是 list,仔细看还可以发现,打印的顺序和原始 list 的顺序有可能是不同的,因为set内部存储的元素是无序的。

set.add(),set.remove()

我们以自定义一个求绝对值的 my_abs 函数为例:

def my_abs(x):
    if x >= 0:
        return x
    else:
        return -x

如果想让一个函数能接受任意个参数,我们就可以定义一个可变参数:可变参数的名字前面有个 * 号,我们可以传入0个、1个或多个参数给可变参数:

def fn(*args):
    print args

你可能感兴趣的:(Python快速学习)