IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> Python知识库 -> 【学习笔记】流畅的Python第二版【第一章】 -> 正文阅读

[Python知识库]【学习笔记】流畅的Python第二版【第一章】

一摞Python风格的纸牌

#!/usr/bin/env python3

import collections
from random import choice

# namedtuple自从python2.6开始就加入到了Python里,用以构建只有少数属性但没有方法的对象,类似于C/C++里面的结构体
Card = collections.namedtuple('Card', ['rank','suit'])

def main():
	class FrenchDeck:
		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, idx):
			return self._cards[idx]
	
	deck = FrenchDeck()
	
	# 打印扑克牌长度
	print(len(deck))
	
	# 抽取第一张牌
	print(deck[0])
	# 抽取最后一张牌
	print(deck[-1])
	
	# 随机抽取一张牌,使用random.choice方法,choice(seq)中传入的值可以是列表,数组,字符串。
	print(choice(deck))
	
	# 查看一摞牌最上面3张和只看牌面是A的牌的操作
	print(deck[:3])
	# 先抽出索引是12的那张牌,然后每隔13张拿1张
	print(deck[12::13])
	
	# 正向迭代
	for card in deck:
		print(card)
	# 反向迭代
	for card in reversed(deck):
		print(card)
		
	# 对一摞扑克牌排序,2最下,A最大,黑桃最大,红桃次之,方块再次,梅花最小。梅花2的大小是0,黑桃A的大小是51.
	suit_values = dict(spades=3, hearts=2, diamonds=1, clubs=0)
	
	def spades_high(card):
		rank_value = FrenchDeck.ranks.index(card.rank)
		return rank_value*len(suit_values)+suit_values[card.suit]
	
	for car in sorted(deck, key=spades_high):
		print(car)
	
if __name__ == '__main__':
	main()

如何使用特殊方法

  1. 特殊方法的存在是为了被Python解释器调用的,你自己并不需要调用他们。尽量少使用my_object.__len__()这种写法,而推荐使用len(my_object)
  2. 如果my_object是一个自定义类的对象,那么Python会自己去调用你实现的__len__方法。
  3. 如果是Python内置的类型,那么 CPython 会抄个近路,__len__实际上会直接返回PyVarObject里的ob_size属性。

模拟数值类型

#!/usr/bin/env python3

from math import hypot 

def main():
	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)
		def __abs__(self):
			return hypot(self.x, self.y)
		def __bool__(self):  # 模非0,显示true
			return bool(abs(self))  # 可以用 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)
		def __mul__(self, scalar):
			return Vector(self.x*scalar, self.y*scalar)
	
	v = Vector(3,4)
	# 查看模数
	print(abs(v))
	# 向量与标量相乘
	v = v*3
	print(v)
	# 两个向量相加
	v1 = Vector(3,4)
	v2 = Vector(1,1)
	print(v1+v2)
	
	
if __name__ == '__main__':
	
	main()

注意

__repr____str__的区别在于,后者是在 str() 函数被使用, 或是在用 print
函数打印一个对象的时候才被调用的,并且它返回的 字符串对终端用户更友好。 如果你只想实现这两个特殊方法中的一个,__repr__
是更好的选择, 因为如果一个对象没有 __str__函数,而 Python又需要调用它的时 候,解释器会用 __repr__作为替代。

  Python知识库 最新文章
Python中String模块
【Python】 14-CVS文件操作
python的panda库读写文件
使用Nordic的nrf52840实现蓝牙DFU过程
【Python学习记录】numpy数组用法整理
Python学习笔记
python字符串和列表
python如何从txt文件中解析出有效的数据
Python编程从入门到实践自学/3.1-3.2
python变量
上一篇文章           查看所有文章
加:2021-11-22 12:17:56  更:2021-11-22 12:20:30 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/16 0:46:40-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码