python 使用建议与技巧分享(四)
作者:songleo 时间:2021-06-29 20:43:28
这是一个系列文章,主要分享python的使用建议和技巧,每次分享3点,希望你能有所收获。
1 如何打印更易读的类
不推荐方式
class Point(object):
def __init__(self, x, y):
self.x = x
self.y = y
p = Point(3, 4)
print p
# <__main__.Point object at 0x0000000001E1B9E8>
推荐方式
class Point(object):
def __init__(self, x, y):
self.x = x
self.y = y
def __repr__(self):
return 'Point({self.x}, {self.y})'.format(self=self)
p = Point(3, 4)
print p
# Point(3, 4)
前一种方式打印的类不易读,不能获取更多的信息。通过类的__repr__方法可以将类打印得更易读。或者不定义__repr__方法,直接使用下面方式打印:
print p.__dict__
# {'y': 4, 'x': 3}
使用__dict__方法,将类以字典形式打印出来,也比较易读。
2 如何将类打印成json字符串
import json
class User(object):
def __init__(self, name, id):
self.name = name
self.id = id
u = User('user1', 1)
print json.dumps(u.__dict__, indent=4)
'''
{
"name": "user1",
"id": 1
}
'''
通过json模块的dumps方法,可以轻易将类打印成json字符串。
3 如何排序类列表
class User:
def __init__(self, name, key):
self.name = name
self.key = key
def __repr__(self):
return 'User({self.name}, {self.key})'.format(self=self)
user_list = [
User('user1', 3),
User('user2', 2),
User('user3', 1),
]
print sorted(user_list, key=lambda user: user.key)
# [User(user3, 1), User(user2, 2), User(user1, 3)]
print sorted(user_list, key=lambda user: user.name)
# [User(user1, 3), User(user2, 2), User(user3, 1)]
这里排序的方法和字典排序类似,第一种是按user的key升序排序,第二种是按user的name升序排序。其实还支持名字相同,再按key进行排序,如下:
user_list = [
User('user1', 3),
User('user1', 2),
User('user1', 1),
]
print sorted(user_list, key=lambda user: (user.name, user.key))
# [User(user1, 1), User(user1, 2), User(user1, 3)]
来源:https://cloud.tencent.com/developer/article/1123062
标签:python,建议,技巧
0
投稿
猜你喜欢
python的Template使用指南
2023-10-14 01:30:58
解决vue组件中click事件失效的问题
2023-07-02 16:34:10
Sql Server2012 使用IP地址登录服务器的配置图文教程
2024-01-26 18:27:25
MySQL 数据库存储和分支
2011-03-11 19:01:00
php Exception异常处理详解
2023-05-29 21:51:37
详谈套接字中SO_REUSEPORT和SO_REUSEADDR的区别
2023-06-07 14:24:23
request基本使用及各种请求方式参数的示例
2021-03-31 02:32:52
Python学习入门之区块链详解
2021-07-15 18:21:55
说说tab设计
2009-07-26 09:56:00
mysql分页性能探索
2024-01-23 22:35:21
Python包argparse模块常用方法
2023-04-03 13:30:58
sql server实现递归查询的方法示例
2024-01-23 00:57:17
sqlserver 支持定位当前页,自定义排序的分页SQL(拒绝动态SQL)
2024-01-16 03:58:06
python检查URL是否正常访问的小技巧
2022-02-23 09:23:56
Discuz7 的提示效果如何实现
2010-01-13 13:10:00
python中is与双等于号“==”的区别示例详解
2023-07-09 22:40:19
linux系统使用python获取cpu信息脚本分享
2021-10-18 17:45:30
php 无法载入mysql扩展
2023-09-07 13:07:40
在Mac OS上安装Oracle数据库的基本方法
2024-01-20 13:57:11
SQL Server 2016正式版安装配置过程图文详解
2024-01-26 05:27:15