1.1现在有一个包含N个元素的元组或者是序列,怎样将它里面的值解压后同时赋值给N个变量

代码:

>>>p = (4,5)

>>>x,y = p

>>>x

4

>>>y

5

>>>data = ['ACME',50,91.1,(2012,12,21)]

>>>name,shares,price,data = data

>>>name

'ACME'

>>>data

(2012,12,21)

>>>name,shares,price,(year,mon,day) = data

>>>name

'ACME'

>>>year

2012

如果变量个数和序列元素的个数不匹配,会产生一个异常。实际上,解压赋值可以用在任何可迭代对象上面,而不仅仅是列表或者元组。包括字符串,文件对象,迭代器和生成器

有时候, 如果只想解压一部分,丢弃其他部分,可以用任意变量去占位,到时候丢掉这些变量就行了

代码:

>>>data = ['ACME',50,91.1,(2012,12,21)]

>>>_,shares,price,_ = data

>>>shares

50

1.2如果一个可迭代对象的元素个数超过变量个数时,回抛出一个ValueError。那么怎样才能从这个可迭代对象中解压出N个元素出来?

代码:

def drop_first_last(grades):

  first,*middle,last = grades

  return avg(middle)

也可以把*号放在最后一个位置,最后一定得到的是一个列表

代码:

>>>record = ('Dave','dave@example.com','773-555-1212','847-555-1212')

>>>name,email,*phone_numbers = record

>>>name

'Dave'

>>>phone_numbers

['773-555-1212','847-555-1212']

也可以把*放在最前面

代码:

*trailing_qtrs,current_qtr = sales_record

trailing_avg = sum(trailing_qtrs)/len(trailing_qtrs)

return avg_comparison(trailing_avg,current_qtr)

1.3在迭代操作或者其他操作的时候,怎样只保留最后有限几个元素的历史记录

代码:

from collections iport deque

def search(lines,pattern,history=5):

  previous_lines = deque(maxlen=history)

  for li in lines:

    if pattern in li:

      yield li,previous_lines

    previous_lines.append(li)

if __name__ == '__main__':

  with open(r'../../cookbook/somefile.txt')as f:

    for line,prevlines in search(f,'python',5):

      for pline in prevlines:

        print(pline,end='')

      print(line,end='')

      print('_'*20)

代码讲解:

首先是deque,使用deque(maxlen=N)构造函数回新建一个固定大小的队列。当新的元素加入并且这个队列已满的时候,最老的元素会自动被移除掉,如果没有指定大小,默认就是无限大

代码示例:

>>>q = deque(maxlen=3)

>>>q.append(1)

>>>q.append(2)

>>>q.append(3)

>>>q

deque([1,2,3],maxlen=3)

>>>q.append(4)

>>>q

deque([2,3,4],maxlen=3)

>>>q=deque()

>>>q.append(1)

>>>q.append(2)

>>>q.append(3)

>>>q

deque([1,2,3])

>>>q.appendleft(4)

>>>q

deque([4,1,2,3])

>>>q.pop()

3

>>>q.popleft()

4

生成器yield的用法讲解

def fab(max):
n, a, b = 0, 0, 1
while n < max:
yield b
# print b
a, b = b, a + b
n = n + 1 '''

仅仅把 print b 改为了 yield b,就在保持简洁性的同时获得了 iterable 的效果。

 >>> for n in fab(5):
... print n
...
1
1
2
3
5

简单地讲,yield 的作用就是把一个函数变成一个 generator,带有 yield 的函数不再是一个普通函数,Python 解释器会将其视为一个 generator,调用 fab(5) 不会执行 fab 函数,而是返回一个 iterable 对象!在 for 循环执行时,每次循环都会执行 fab 函数内部的代码,执行到 yield b 时,fab 函数就返回一个迭代值,下次迭代时,代码从 yield b 的下一条语句继续执行,而函数的本地变量看起来和上次中断执行前是完全一样的,于是函数继续执行,直到再次遇到 yield。

1.4、怎样从一个集合中获得最大或者最小的N个元素列表

heapq模块有两个函数:nlargest和nsmallest()可以解决

代码:

import heapq

nums = [1,8,2,23,7,-4,18,23,42,37,2]

print(heapq.nlargest(3,nums))

print(heapq.lsmallest(3,nums))

两个函数都能接受一个关键字参数,用于更复杂的数据结构中:

代码:

portfolio = [

{'name':'IBM','shares':100,'price':91.1},

{'name': 'AAPL', 'shares': 50, 'price': 543.22},

{'name': 'FB', 'shares': 200, 'price': 21.09},

{'name': 'HPQ', 'shares': 35, 'price': 31.75},

{'name': 'YHOO', 'shares': 45, 'price': 16.35},

{'name': 'ACME', 'shares': 75, 'price': 115.65}

]

cheap = heapq.nsmallest(3,portfolio,key=lambda s:s['price'])

expensive = heapq.nlargest(3,portfolio,key=lambda s:s['price'])

heapq的排序函数heapify

>>>nums = [1,8,2,23,7,-4,18,23,42,37,2]

>>>import heapq

>>>heapq.heapify(nums)

>>>nums

[-4, 2, 1, 23, 7, 2, 18, 23, 42, 37, 8]

>>>heapq.heappop(nums)

-4

如果是查找唯一的最大或者最小的话,可以直接使用min()和max()

如果N接近集合的大小的话,可以直接用sorted先排序再取sorted(items)[:N]或者sorted(items)[_N:]

cookbook学习第一弹的更多相关文章

  1. Office宏病毒学习第一弹--恶意的Excel 4.0宏

    Office宏病毒学习第一弹--恶意的Excel 4.0宏 前言 参考:https://outflank.nl/blog/2018/10/06/old-school-evil-excel-4-0-ma ...

  2. Python3 学习第一弹:基本数据类型

    本人学习主要从<python基础教程第二版>,<dive into python3>等书籍,及一些网上大牛的博客中学习特别是Python官方文档<Python Tutor ...

  3. Python学习第一弹——Python环境搭建

    一.Python简介: Python,是一种面向对象.解释型计算机程序设计语言,由Guido van Rossum于1989年底发明,第一个公开发行版发行于1991年.Python语法简洁而清晰,具有 ...

  4. Java高精度学习第一弹

    为了快速解决高精度问题,总算是要来接触java了,算上这学期要开java的课了,好好学习吧! 拿来练手的是hdu的1002,高精度加法. import java.util.*; import java ...

  5. css学习の第一弹—格式创建

    构成结构:选择符(又称为选择qi器){声明(属性:值):}*****注意:大括号,冒号,每个声明后的分号. 注释:/*注释内容写在这里*/ 一.css样式 css样式写的地方的不同分类:内联式.嵌入式 ...

  6. html学习第一弹の常用标签的归类

    HTML初步学习: 行内元素:只占据他对应标签的边框所包含的空间,默认横向排布. 块级元素:块级元素占据其父元素(容器)的整个空间,因此创建了一个块,通常浏览器会在块级元素前后另起一行,默认竖向排布. ...

  7. WebService学习-第一弹

    一:WebService简介(1)简介----百度百科(注意标识的重点) Web service是一个平台独立的,低耦合的,自包含的.基于可编程的web的应用程序,可使用开放的XML(标准通用标记语言 ...

  8. FluentData 学习 第一弹

    地址: http://fluentdata.codeplex.com/ 前世: FluentData 我们公司用的一个增删改查的里面的持久层.之前还不知道 这个持久层叫FluentData.  某天看 ...

  9. cookbook学习第二弹

    1.5怎样实现一个按优先级排序的队列?并且在这个队列上面每次pop操作总是返回优先级最高的那个元素 带有双下划线的方法,会在需要被调用的位置自动被调用 带有单下划线的变量是私有变量 下面利用类heap ...

随机推荐

  1. js公有、私有、静态属性和方法的区别

          现下,javascript大行其道,对于网站开发人员来说,javascript是必需掌据的一门语言,但随着jquery等框架的流行和使用,许多人对于原生javascript缺乏深入的理解, ...

  2. 由addOneMember引发的思考

    addOneMember是一个方法,这个方法在两处地方重复了. 所以在修改页面的时候,发现修改了一处,如果是新手,肯定不会注意到另外一处有问题,他如果没有看清楚这个类到底整体怎样,那么他会犯的错误是就 ...

  3. oracle视图

    视图 SELECT -- int.rowner "rgroup owner", -- int.rname "refresh group", mv.owner a ...

  4. RColorBrewer包---R语言的配色方案

    // RColorBrewer包介绍 RColorBrewer包提供了3套很好的配色方案.用户只需要指定配色方案的名称,就可以用包中的brewer.pal()函数生成颜色.这3套配色方案包括: 连续型 ...

  5. XIII Open Cup named after E.V. Pankratiev. GP of Azov Sea

    A. Freestyle 如果逆序对为$0$,那么先手必败. 因为每次只能翻转长度为$4k+2$和$4k+3$的区间,所以每次操作之后逆序对的奇偶性一定会发生改变. 因此如果逆序对个数为偶数,则先手必 ...

  6. hihoCoder#1384 : Genius ACM

    对于一个固定的区间$[l,r]$,显然只要将里面的数字从小到大排序后将最小的$m$个和最大的$m$个配对即可. 如果固定左端点,那么随着右端点的右移,$SPD$值单调不降,所以尽量把右端点往右移,贪心 ...

  7. JS 特殊字符的魅力

    特殊字符的魅力 说在前面—鸭子类型 鸭子类型是动态类型的一种风格,在这种风格中,一个对象有效的语义,不是由继承自特定的类或者实现特定的接口,而是由当前方法和属性的集合决定. “当看到一只鸟走起来像鸭子 ...

  8. 【BZOJ】1975: [Sdoi2010]魔法猪学院

    题意 \(n(2 \le n \le 5000)\)个点,找尽量多的不同\(1\)到\(n\)的路径,每一次的花费就是路径的全值和,要求在费用不超过\(E\)的情况下路径最多. 分析 裸的最段路. 题 ...

  9. 【BZOJ2190】【SDOI2008】仪仗队

    Description 作为体育委员,C君负责这次运动会仪仗队的训练.仪仗队是由学生组成的N * N的方阵,为了保证队伍在行进中整齐划一,C君会跟在仪仗队的左后方,根据其视线所及的学生人数来判断队伍是 ...

  10. PHP面向对象学习一

    1. 抽象性 ,  2. 封装性 ,3.共享性 ,4. 强调对象结构而不是程序结构 面向对象的三大特点(封装,继承,多态)缺一不可 class MyPc{ ———创建一个名为 MyPc的类,class ...