python学习笔记-基础篇续

列表

list是处理一组有序项目的数据结构,可以在一个列表中存储一个序列的项目。列表是可变的数据类型。

shoplist = ['apple','amngo','carrot','banana']

list的主要方法有:

  • len()
  • append():在列表尾部添加一个项目
  • sort()

list和tuple-元组

要删除 list 末尾的元素用 pop()
要删除指定位置的元素,用 pop(i)方法,其中 i 是索引位置
另一种有序列表叫元组:tuple。tuple 和 list 非常类似,但 tuple 一旦初始化就不能修改。
classmate = ('Michael','Bob','Tracy')
如果定义只有一个元素的tuple:
t = (1,)

元组最常用的地方是用在输出中:

#!/usr/bin/python
# Filename: print_tuple.py
age = 22
name = 'Swaroop'
print '%s is %d years old' % (name, age)
print 'Why is %s playing with that python?' % name

结果:

$ python print_tuple.py
Swaroop is 22 years old
Why is Swaroop playing with that python?

print语句可以使用跟着%符号的项目元组的字符串。

字典-dict

names = {'Michael':95,'Bob':75,'Tracy':85}
for name, address in names.items():#遍历输出键和值
    print '%s is %d years old.' %(name, address)

实现原理:给定一个名字,比如 Michael ,dict 在内部就可以直接计算出 Michael 对应的存放成绩的“页码”,也就是 95 这个数字存放的内存地址,直接取出来,所以速度非常快。
函数:函数名其实就是指向一个函数对象的引用,完全可以把函数名赋给一个变量,相当于给这个函数起了个“别名”:

a = abs #变量a指向abs函数
a(-1)   #所以也可以通过a调用abs函数

空函数:

def nop():
    pass

Python的返回多值其实就是返回一个tuple

默认参数

def add_end(L = []):
    L.append("END")
    return L
b = add_end()
print b
c = add_end()
print c

结果:

['END']
['END','END']

为什么会这样呢?
Python 函数在定义的时候,默认参数 L 就计算出来了,即 [] ,因为默认参数 L 也是一个变量,它指向对象 [] ,每次调用该函数,如果改变了L的内容,则下次调用时,默认参数的内容就变了,不再是函数定义时的 [] 了`。
定义默认参数时:默认参数必须指向不变对象。
改进:

def add_end2(L = None):
    if L is None:
        L = []
    L.append('END')
    return L

d = add_end2()
print d
e = add_end2()
print e

结果:

['END']
['END']

递归函数

def fact(n): 
    if n == 1:
        return 1 
    return n*fact(n-1) 
print fact(100) 

这样可以计算fact(n) = 1 × 2 × 3 × ... × (n-1) × n
使用递归函数要防止栈溢出。在计算机中,函数的调用是通过栈(stack)这种数据结构实现的,每当进入一个函数调用,栈就会加一层栈帧,每当函数返回,栈就会减一层栈帧。由于栈的大小不是无限的,所以,递归调用的次数过多,就会导致溢出。
解决方法:尾递归优化
尾递归是指,在函数返回的时候,调用函数自身,并且,return语句不能包含表达式。这样,编译器或者解释器就可以把尾递归做优化,使递归本身无论调用多少次,都只占用一个栈帧,不会出现栈溢出的情况。

def fact2(n):
    return fact_iter(n,1)

def fact_iter(num,product):
    if num == 1:
        return product
    return fact_iter(num - 1,num * product)

字符串的方法

startwith方法是用来测试字符串是否以给定字符串开始。
in操作符用来检验一个给定字符串是否为另一个字符串的一部分。
find方法用来找出给定字符串在另一个字符串中的位置

高级特性

列表、元组和字符串都是序列。序列的两个主要特点是:

  • 索引操作符:可以让我们从序列中抓取一个项目
  • 切片操作符:让我们能够获取序列的一个切片,即一部分序列。

切片

取一个list或tuple的部分元素是很常见的操作。
list:
假如有一个列表L,L = []

L[0:3]表示,从索引0开始取,知道索引3为止,但不包括索引3。
L[:10:2]表示前十个值,每两个取一个。
L[::5]所有值,每五个取一个

tuple:

(0,1,2,3,4,5)[:3]
(0,1,2)

字符串:

'abcdefg'[:3]
'abc'
'ABCDEFG'[::2]
'ACEG'

迭代

dict:

for key in d                #默认,迭代key
for value in d.itervalues() #迭代value
for k,v in d.iteritems()    #同时迭代key和value

判断一个对象是否可以迭代:

from collections import Iterable
isinstance('abc',Iterable)       #判断str是否可以迭代

enumrate函数:可以把list变成索引-元素对

for i, value in enumrate(['a','b','c']):
    print i,value

列表生成式
要生成[1×1,2×2, ... ,10×10]怎么做?

>>>[x*x for x in range(1,11)]
[1, 4, 9, 16, 25, 36, 49, 64, 81, 100]

使用两层循环生成全排列:

>>> [m + n for n in 'abc'for m in 'def']
['da', 'ea', 'fa', 'db', 'eb', 'fb', 'dc', 'ec', 'fc']

列出当前目录下的所有文件和目录名:

>>> import os
>>> [d for d in os.listdir('.')]
['DLLs', 'Doc', 'helloworld.py', 'include', 'Lib', 'libs', 'LICENSE.txt', 'NEWS.txt', 'python.exe', 'pythonw.exe', 'README.txt', 'Scripts', 'tcl', 'Tools', 'var.py', 'w9xpopen.exe']

列表生成式可以使用两个变量来生成list:

>>> d = {'x':'A','y':'B','z':'C'}
>>> [k+'='+v for k,v in d.iteritems()]
['y=B', 'x=A', 'z=C']

把一个list中所有的字符串变成小写:

>>> L = ['Hello','World','IBM','Apple']
>>> [s.lower() for s in L]
['hello', 'world', 'ibm', 'apple']

生成器
在python中,一边循环,一边计算的机制,称为生成器(Generator)

>>> g= (x*x for x in range(1,10))
>>> g
<generator object <genexpr> at 0x0299DCD8
>>> g.next()
1
>>> g.next()
4
>>> g.next()
9
>>> g.next()
16
>>> g.next()
25
>>> g.next()
36
>>> g.next()
49
>>> g.next()
64
>>> g.next()
81
>>> g.next()
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
StopIteration

输出斐波那契数列的前N个数:

def fib(max):
    n, a, b = 0, 0, 1
    while n < max:
        print b
        a ,b = b, a+ b
        n = n + 1

fib(6)
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 221,273评论 6 515
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 94,349评论 3 398
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 167,709评论 0 360
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 59,520评论 1 296
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 68,515评论 6 397
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 52,158评论 1 308
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,755评论 3 421
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,660评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 46,203评论 1 319
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 38,287评论 3 340
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,427评论 1 352
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 36,122评论 5 349
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,801评论 3 333
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,272评论 0 23
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,393评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,808评论 3 376
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,440评论 2 359

推荐阅读更多精彩内容

  • 最近在慕课网学习廖雪峰老师的Python进阶课程,做笔记总结一下重点。 基本变量及其类型 变量 在Python中,...
    victorsungo阅读 1,699评论 0 5
  • http://python.jobbole.com/85231/ 关于专业技能写完项目接着写写一名3年工作经验的J...
    燕京博士阅读 7,582评论 1 118
  • 一、python 变量和数据类型 1.整数 Python可以处理任意大小的整数,当然包括负整数,在Python程序...
    绩重KF阅读 1,712评论 0 1
  • 教程总纲:http://www.runoob.com/python/python-tutorial.html 进阶...
    健康哥哥阅读 2,035评论 1 3
  • 导读:管理学最早的时候叫管理模式。管理模式的主要内容就是企业内部的人怎么招,部门怎么设置,管理流程怎么做。流程其实...
    经营小管家阅读 723评论 0 0