1.  Example of two-dimensional vector: Vector(2,4) + Vector(2,1) results in Vector(4,5)

import math

# special methods used: __repr__ , __abs__ , __add__ , __mul__

class Vector:

    def __init__(self, x=0, y=0):
self.x = x
self.y = y def __repr__(self):
return "Vector(%r, %r)" % (self.x, self.y)
# we use %r to obtain the standard representation of the attributes to be displayed.
# !r should be used in the str.format method. def __abs__(self):
return math.hypot(self.x, self.y)
# math.hypot(x, y) 即相当于 math.sqrt(x*x + y*y) def __bool__(self):
"""
By default, instances of user-defined classes are considered truthy, unless either __bool__ or __len__ is
implemented. Basically, bool(x) calls x.__bool__() and uses the result. If __bool__ is not implemented, Python
tries to invoke x.__len__(), and if that returns zero, bool returns False. Otherwise bool returns True.
:return:
"""
return bool(self.x or self.y) def __add__(self, other):
x = self.x + other.x
y = self.y + other.y
return Vector(x, y) # create and return a new instance of Vector def __mul__(self, other):
return Vector(self.x * other, self.y * other) """
in both __add__ and __mul__ , the methods should create and return a new instance of Vector, and DO NOT modify
either operand -- 'self' or 'other' (应该生成新的对象)
""" v1 = Vector(2, 4)
v2 = Vector(2, 1) print(v2)
print("add: v1 + v2", v1 + v2) v = Vector(3, 4)
print("abs(3,4)", abs(v)) print("v * 3", v * 3) print("abs(v*3)", abs(v * 3))

2.1.  列表生成式的嵌套 for 循环:

示例如下:

li1 = range(1,6)
li2 = list("ABC") # list("ABC") 的结果为 ["A", "B", "C"] for m in li1:
for n in li2:
print((m,n)) li = [(m,n) for m in li1 for n in li2]
print(li) # 输出结果:
(1, 'A')
(1, 'B')
(1, 'C')
(2, 'A')
(2, 'B')
(2, 'C')
(3, 'A')
(3, 'B')
(3, 'C')
(4, 'A')
(4, 'B')
(4, 'C')
(5, 'A')
(5, 'B')
(5, 'C')
[(1, 'A'), (1, 'B'), (1, 'C'), (2, 'A'), (2, 'B'), (2, 'C'), (3, 'A'), (3, 'B'), (3, 'C'), (4, 'A'), (4, 'B'), (4, 'C'), (5, 'A'), (5, 'B'), (5, 'C')] # 列表生成式中的 两个 for 循环 作用就相当于 for 循环的嵌套

参考链接: https://www.jb51.net/article/150400.htm

2.2   A Pythonic Card Deck: __len__ & __getitem__

示例如下:

import collections

Card = collections.namedtuple("Card", ["rank", "suit"])

class FrenchDeck(object):
ranks = [str(n) for n in range(2, 11)] + list("JQKA")
suits = "spades diamonds clubs hearts".split() def __init__(self):
self._cards = [Card(rank, suit) for suit in self.suits
for rank in self.ranks] def __len__(self):
return len(self._cards) def __getitem__(self, position):
return self._cards[position] deck = FrenchDeck() print(len(deck)) # len() 实际只适合 dict, list 等;想要 适用于 deck ,就需要重写 __len__ 方法 # output:
# print(deck[0], deck[1]) # __getitem__ delegates to the [] operator
"""
Special methods是理解Python语言的关键之一。例如,__getitem__特殊方法用来支持obj[key]。因此,当实现my_collection[key],解释器实际上调用的是my_collection.__getitem__(key)
""" # output:
# Card(rank='2', suit='spades') Card(rank='3', suit='spades') import random print(random.choice(deck))
print(random.choice(deck))
print(random.choice(deck)) # output:
# Card(rank='8', suit='clubs')
# Card(rank='J', suit='clubs')
# Card(rank='2', suit='diamonds') """
random.choice(seq) 的原理:
random.choice内部实现是先用len方法获取总长度然后从0到总长度时间取一个随机数作为索引获取 源码如下:
def choice(self, seq):
# Choose a random element from a non-empty sequence.
try:
i = self._randbelow(len(seq))
except ValueError:
raise IndexError('Cannot choose from an empty sequence') from None
return seq[i]
""" # 切片: class slice(start, stop[, step]) print(deck[12::13]) # output:
# [Card(rank='A', suit='spades'), Card(rank='A', suit='diamonds'),
# Card(rank='A', suit='clubs'), Card(rank='A', suit='hearts')] for card in deck:
print(card)
# by implementing the __getitem__ special method, deck is also iterable
# the statement -- for i in x: actually causes the invocation of iter(x), which in turn may call x.__iter__() if that is possible. # the deck can also be iterated in reverse :
for card in reversed(deck):
print(card) """
reversed(seq)
Return a reverse iterator. seq must be an object which has a __reversed__() method or supports the sequence protocol (the __len__() method and the __getitem__() method with integer arguments starting at 0).
""" print(Card("Q", "hearts") in deck)
print(Card("", "beasts") in deck) # output:
# True
# False # 特殊方法 __contains__ 是用来进行in检验的。 # Sorting:
"""
要求:
A common system of ranking cards is by rank(with aces being highest),then by suit the order of spades(highest), then hearts,
diamonds, and clubs(lowest).
"""
suit_values = dict(spades=3, hearts=2, diamonds=1, clubs=0) def spades_high(card):
card_rank = FrenchDeck.ranks.index(card.rank)
return card_rank * len(suit_values) + suit_values[card.suit] for card in sorted(deck, key=spades_high):
  # deck 中的每个 item 会传为 spades_high 的参数 传入 spades_high 中
print(card) """
By implementing the special methods __len__ and __getitem__ , our FrenchDeck behaves like a standard Python sequence. The `list.sort` method sorts a list in place -- that is, without making a copy. (list.sort 方法是对一个列表进行【就地】排序;返回 None);
In contrast , the built-in function `sorted` creates a new list and returns it. (返回排序后的 list)
"""

A Pythonic Card Deck: __len__ & __getitem__ & for 循环的嵌套的更多相关文章

  1. python中的__len__,__getitem__ __setitem__ __delitem__ __contains__

    可变集合需要实现: __len__  __getitem__    __setitem__  __delitem__不可变集合需要实现: __len__  __getitem__ __len__:返回 ...

  2. for循环的嵌套,for循环的穷举迭代

    for循环的嵌套            输入一个正整数,求阶乘的和 嵌套            Console.Write("请输入一个正整数:");            int ...

  3. 【C语言】-循环的嵌套

    循环的嵌套:当在一个循环语句中嵌入另一个循环时,成为循环的嵌套. 循环嵌套的形式: (1)for语句中嵌入for语句: for ( ) { for ( ) { ... } } (2)for语句嵌入wh ...

  4. C语言循环的嵌套

    注:参考网络资源拟制,如雷同请见谅循环的嵌套:一个循环体语句中又包含另一个循环语句,称为循环嵌套.嵌套注意事项:1.使用循环嵌套时,内层循环和外层循环的循环控制变量不能相同.2.循环嵌套结构的书写,最 ...

  5. 2017-2-24 C#基础 for循环的嵌套

    用几个练习题演示一下for循环的嵌套 1.打印以下图形 ★★★★★★★★★★★★★★★ namespace _2017_2_24_for循环的嵌套 { class Program { static v ...

  6. for循环中嵌套setTimeout,执行顺序和结果该如何理解?

    这两天在捣鼓作用域的问题,有的时候知识这个东西真的有点像是牵一发而动全身的感觉.在理解作用域的时候,又看到了一道经典的面试题和例子题. 那就是在for循环中嵌套setTimeout延时,想想之前面试的 ...

  7. for 循环与嵌套

    循环:反复执行某段代码.循环四要素:初始条件,循环条件,循环体,状态改变 for(初始条件;循环条件;状态改变){ 循环体} 给出初始条件,先判断是否满足循环条件,如果不满足条件则跳过for语句,如果 ...

  8. .Net基础篇_学习笔记_第六天_for循环的嵌套_乘法口诀表

    using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...

  9. for循环中嵌套异步请求问题

    for循环中嵌套了异步请求会导致顺序错乱,用递归代替for循环,可以保证正常执行顺序:

随机推荐

  1. Python 调用JS文件中的函数

    Python 调用JS文件中的函数 1.安装PyExecJS第三方库 2.导入库:import execjs 3.调用JS文件中的方法 Passwd = execjs.compile(open(r&q ...

  2. 6and7.Pod控制器应用进阶

    Pod控制器应用进阶:imagepullpolicy: 镜像获取策略 Always,Never,IfNoPresent 暴露端口: portslabels 标签可以后期添加修改. ========== ...

  3. k8s创建资源的两种方式(5)

    一.创建方式分类: 命令 vs 配置文件 Kubernetes 支持两种方式创建资源: 1.用 kubectl 命令直接创建,比如: kubectl run httpd-app --image=reg ...

  4. docker数据管理(2)

    一.docker存储资源类型 docker两种存储资源类型 用户在使用 Docker 的过程中,势必需要查看容器内应用产生的数据,或者需要将容器内数据进行备份,甚至多个容器之间进行数据共享,这必然会涉 ...

  5. React Native细节知识点总结<一>

    1.propTypes: static propTypes = { name:PropTypes.string, ID:PropTypes.number.isRequired, } 'isRequir ...

  6. 【JVM学习笔记】线程上下文类加载器

    有许多地方能够看到线程上下文类加载的设置,比如在sun.misc.Launcher类的构造方法中,能够看到如下代码 先写一个例子建立感性认识 public class Test { public st ...

  7. JRebel for IntelliJ

    好久没用jrebel了,跟前端进行项目联调总是有些许改动,还是热部署方便. 目前用的idea版本:IntelliJ IDEA 2019.2 JRebel插件版本:JRebel for IntelliJ ...

  8. RocketMQ之九:RocketMQ消息发送流程解读

    在讨论这个问题之前,我们先看一下Client的整体架构. Producer与Consumer类体系 从下图可以看出以下几点:(1)Producer与Consumer的共同逻辑,封装在MQClientI ...

  9. HTML5元素周期表

    HTML5元素周期表 根元素 1. html 文档根元素 元数据和脚本 1. head HTML文档中的第一个元素.包含文档元数据 2. title 文档标题 3. meta 文档的元数据. meta ...

  10. C语言递归之求根到叶节点数字之和

    题目描述 给定一个二叉树,它的每个结点都存放一个 0-9 的数字,每条从根到叶子节点的路径都代表一个数字. 例如,从根到叶子节点路径 1->2->3 代表数字 123. 计算从根到叶子节点 ...