Python用起来极度舒适的强大背后
当你使用len(a)获取a的长度,使用obj[key]获取一个key的值时的畅快和舒适,在于Python庞大的设计思想(Pythonic)。
而obj[key]背后其实是__getitem__方法,Python实现的会被框架本身调用的方法之一。像__len__,__getitem__这样的方法称为特殊方法或者双下方法。
下面用一个例子展示如何实现这两个特殊方法,以及见证特殊方法的强大:
此处用到collections模块中的namedtuple方法,返回一个具名元组子类。
# -*- coding: utf-8 -*-
# Nola import collections
from random import choice Card = collections.namedtuple('Card', ['rank', 'suit']) # 返回具有命名字段的元组的新子类 表示一张牌 suit_values = dict(spades=3, hearts=2, diamonds=1, clubs=0) # ♣->♦->♥->♠ 2-A 花色和大小从小到大 0(2梅花色)-51(A黑桃色) 花色大小映射 def spades_high(card):
"""
纸牌升序
:param card:
:return:
"""
rank_value = FrenchDeck.ranks.index(card.rank) # 获取纸牌大小index
return rank_value * len(suit_values) + suit_values[card.suit] # 纸牌大小index * 4色 + 花色权重 2clubs=0 2diamonds=1 class FrenchDeck(object):
# ['2', '3', '4', '5', '6', '7', '8', '9', '10', 'J', 'Q', 'K', 'A'] 13
ranks = [str(n) for n in range(2, 11)] + list('JQKA')
suits = 'spades diamonds clubs hearts'.split() # ['spades', 'diamonds', 'clubs', 'hearts'] 4 def __init__(self):
self._cards = [Card(rank, suit) for rank in self.ranks
for suit in self.suits] def __len__(self):
return len(self._cards) def __getitem__(self, position):
return self._cards[position] if __name__ == '__main__':
# namedtuple用法
Point = collections.namedtuple('Point', ['x', 'y'])
print(Point.__doc__) # docstring Point(x, y)
p = Point(11, 22)
print(p[0] + p[1]) # 使用index
x, y = p # 像元组一样解包
print(x, y)
print(p.x, p.y) # 使用字段名获取对应值
d = p._asdict() # 转为dict OrderedDict([('x', 11), ('y', 22)]) 11 22
print(d, d['x'], d['y'])
print(Point(**d)) # dict打包为新子类 Point(x=11, y=22)
print(p._replace(x=100)) # 类似str替换 Point(x=100, y=22)
print('@.@ '*20 + "\n"*2) # 得到一个纸牌对象
beer_card = Card('', 'diamonds')
print(beer_card) # Card(rank='7', suit='diamonds')
print('@.@ ' * 20 + "\n"*2) # len函数查看一叠牌有多少张
deck = FrenchDeck()
print(len(deck)) #
print('@.@ ' * 20 + "\n"*2) # 使用__getitem__方法从一叠牌中抽取特定的一张牌
print(deck[0]) # 第一张 Card(rank='2', suit='spandes')
print(deck[-1]) # 最后一张 Card(rank='A', suit='hearts')
print('@.@ ' * 20 + "\n" * 2) # 使用python内置函数random.choice随机抽取一张牌
print(choice(deck)) # Card(rank='9', suit='hearts')
print(choice(deck)) # Card(rank='3', suit='diamonds')
print('@.@ ' * 20 + "\n" * 2) # 抽取最上面3张
print(deck[:3])
# 只看牌面是A的牌
print(deck[-4:])
print(deck[48:])
print('@.@ ' * 20 + "\n" * 2) # 仅仅实现__getitem__方法,这一摞牌就编程可迭代了
for card in deck[:5]:
print(card)
print('@.@ ' * 20 + "\n" * 2) # 反迭代reverse list
for card in reversed(deck):
if card.rank == "K":
break
print(card)
print('@.@ ' * 20 + "\n" * 2) # in运算符可用在FrenchDeck类上,因为它是可迭代的
print(Card('Q', 'diamonds') in deck)
print(Card('S', 'diamonds') in deck)
print('@.@ ' * 20 + "\n" * 2) # spades_high函数对牌进行升序排序 标准库中sorted函数自增可根据指定key自增排序 reverse参数为True倒序
for card in sorted(deck[:8], key=spades_high, reverse=True):
print(card)
# Card(rank='3', suit='spades')
# Card(rank='3', suit='hearts')
# Card(rank='3', suit='diamonds')
# Card(rank='3', suit='clubs')
# Card(rank='2', suit='spades')
# Card(rank='2', suit='hearts')
# Card(rank='2', suit='diamonds')
# Card(rank='2', suit='clubs')
print('@.@ ' * 20 + "\n" * 2)
Python用起来极度舒适的强大背后的更多相关文章
- 极度舒适的 Python 入门教程,小猪佩奇也能学会~
编程几乎已经成为现代人的一门必修课,特别是 Python ,不仅长期霸占编程趋势榜.薪资榜第一,还屡屡进入小学教材,甚至成为浙江省信息技术高考项目-- 今天,小编带来了一门极度舒适的 Python 入 ...
- 01--[转]C++强大背后
[转]C++强大背后 2014-01-22 分类:互联网 阅读(9295) 评论(6) 在31年前(1979年),一名刚获得博士学位的研究员,为了开发一个软件项目发明了一门新编程语言,该研究员名为Bj ...
- Python和SQL Server 2017的强大功能
Python和SQL Server 2017的强大功能 摘要: 源:https://www.red-gate.com/simple-talk/sql/sql-development/power-pyt ...
- 机器学习入门:极度舒适的GBDT原理拆解
机器学习入门:极度舒适的GBDT拆解 本文旨用小例子+可视化的方式拆解GBDT原理中的每个步骤,使大家可以彻底理解GBDT Boosting→Gradient Boosting Boosting是集成 ...
- C++强大背后
转自MiloYip大神的博客 [原文]http://www.cnblogs.com/miloyip/archive/2010/09/17/behind_cplusplus.html 在31年前(197 ...
- python的with语句,超级强大
With语句是什么? 有一些任务,可能事先需要设置,事后做清理工作.对于这种场景,Python的with语句提供了一种非常方便的处理方式.一个很好的例子是文件处理,你需要获取一个文件句柄,从文件中读取 ...
- 如何在Python中实现这五类强大的概率分布
R编程语言已经成为统计分析中的事实标准.但在这篇文章中,我将告诉你在Python中实现统计学概念会是如此容易.我要使用Python实现一些离散和连续的概率分布.虽然我不会讨论这些分布的数学细节,但我会 ...
- IDEA 公司推出新字体,极度舒适~
这几天炒得沸沸扬扬的 Intellij IDEA 公司 JetBrains 推出了一种新字体:JetBrains Mono,据说它是专为开发人员设计的,下面栈长带大家一起来吃个瓜. JetBrains ...
- 吴裕雄--天生自然python学习笔记:pandas模块强大的数据处理套件
用 Python 进行数据分析处理,其中最炫酷的就属 Pa ndas 套件了 . 比如,如果我 们通过 Requests 及 Beautifulsoup 来抓取网页中的表格数据 , 需要进行较复 杂的 ...
随机推荐
- python 识别图片上的数字
https://blog.csdn.net/qq_31446377/article/details/81708006 ython 3.6 版本 Pytesseract 图像验证码识别 环境: (1) ...
- ElasticSearch(八)Elasticsearch-head 连接不上Elasticsearch的原因和解决方案
在上篇博文里ElasticSearch(七) Elasticsearch在Centos下搭建可视化服务中已经访问到了可视化界面.然后兴奋地进行了数据提交测试,提交啊,刷新啊,就是看不到数据变化,仔细一 ...
- JS getBoundingClientRect()
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- 详解ASP.NET Core API 的Get和Post请求使用方式
上一篇文章帮助大家解决问题不彻底导致博友使用的时候还是遇到一些问题,欢迎一起讨论.所以下面重点详细讲解我们常用的Get和Post请求( 以.net core2.2的Http[Verb]为方向 ,推荐该 ...
- 使用win10的开始屏幕,在系统中设置简洁、快捷桌面
前几天入手了一个本本,由于之前电脑使用的柠檬桌面软件和现在本本的分辨率不适应,意外发现win10自带的开始屏幕整理桌面也是很有意思,再加上触摸板的手势,瞬间觉得整个电脑都清洁许多.废话少说,开始上料. ...
- day3——两数之和
// 小白一名,0算法基础,艰难尝试算法题中,若您发现本文中错误, 或有其他见解,往不吝赐教,感激不尽,拜谢. 领扣 第2题 今日算法 题干 //给定一个整数数组和一个目标值,找出数组中和为目标值的两 ...
- Cordova入门系列(四)自定义Cordova插件--showToast
前三篇Cordova入门系列,简单讲解了Cordova,以及如何调用Cordova插件,今天我们讲解一下如何自己做一个插件. 自定义插件,就是自己写一些安卓java代码,然后和js代码以及配置文件,封 ...
- Evaluate X and Y returned from the differential equation solvers using printput frequency in Python的代码
把内容过程中经常用到的一些内容段做个备份,如下的内容是关于Evaluate X and Y returned from the differential equation solvers using ...
- Nginx 常用配置
Nginx的负载均衡方式 1.轮询(默认) 每个请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器down掉,能自动剔除. 2.weight 指定轮询几率,weight和访问比率成正比,用于后端 ...
- Spring MVC 返回Json数据环境记录
Spring 版本 Spring4.3.18 Json包 jackson-annotations-2.9.8.jar jackson-core-2.9.8.jar jackson ...