百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程字典 > 正文

Python 中那些令人拍案叫绝的功能

toyiye 2024-08-22 02:28 5 浏览 0 评论

私信我,回复:学习,获取免费学习资源包。

在使用Python多年以后,我偶然发现了一些我们过去不知道的功能和特性。一些可以说是非常有用,但却没有充分利用。考虑到这一点,我编辑了一些你应该了解的Python功能特色。

00.带任意数量参数的函数


你可能已经知道了Python允许你定义可选参数。但还有一个方法,可以定义函数任意数量的参数。

首先,看下面是一个只定义可选参数的例子:

def function(arg1="", arg2=""):
 print "arg1: {0}".format(arg1)
 print "arg2: {0}".format(arg2)
function("Hello", "World")
# prints args1: Hello
# prints args2: World
function()
# prints args1:
# prints args2:

现在,让我们看看怎么定义一个可以接受任意参数的函数。我们利用元组来实现。

def foo(*args): 
 # just use "*" to collect all remaining arguments into a tuple
 numargs = len(args)
 print "Number of arguments: {0}".format(numargs)
 for i, x in enumerate(args):
 print "Argument {0} is: {1}".format(i, x)
foo()
# Number of arguments: 0
foo("hello")
# Number of arguments: 1
# Argument 0 is: hello
foo("hello", "World", "Again")
# Number of arguments: 3
# Argument 0 is: hello
# Argument 1 is: World
# Argument 2 is: Again


小编补充:更一般的函数定义方式是def fun(*args,**kwargs),可以在许多Python源码中发现这种定义,其中*args表示任何多个无名参数,它本质是一个元组tuple;**kwargs表示关键字参数,它本质上是一个字典dict。

01.使用Glob()查找文件


大多Python函数有着长且具有描述性的名字。但是命名为glob()的函数你可能不知道它是干什么的除非你从别处已经熟悉它了。

它像是一个更强大版本的listdir()函数。它可以让你通过使用模式匹配来搜索文件。

import glob
# get all py files
files = glob.glob('*.py')
print files
# Output
# ['arg.py', 'g.py', 'shut.py', 'test.py']

你可以像下面这样查找多个文件类型:

import itertools as it, glob
def multiple_file_types(*patterns):
 return it.chain.from_iterable(glob.glob(pattern) \
 for pattern in patterns)
for filename in multiple_file_types("*.txt", "*.py"): 
 # add as many filetype arguements
 print filename
# output
# =========#
# test.txt
# arg.py
# g.py
# shut.py
# test.py

如果你想得到每个文件的绝对路径,你可以在返回值上调用realpath()函数:

import itertools as it, glob, os
def multiple_file_types(*patterns):
 return it.chain.from_iterable(glob.glob(pattern) \
 for pattern in patterns)
for filename in multiple_file_types("*.txt", "*.py"): 
 # add as many filetype arguements
 realpath = os.path.realpath(filename)
 print realpath
# output
#=========#
# C:\xxx\pyfunc\test.txt
# C:\xxx\pyfunc\arg.py
# C:\xxx\pyfunc\g.py
# C:\xxx\pyfunc\shut.py
# C:\xxx\pyfunc\test.py

02.调试


下面的例子使用inspect模块。该模块用于调试目的时是非常有用的,它的功能远比这里描述的要多。

这篇文章不会覆盖这个模块的每个细节,但会展示给你一些用例。

import logging, inspect
logging.basicConfig(level=logging.INFO,
 format='%(asctime)s %(levelname)-8s %(filename)s:%(lineno)-4d: %(message)s',
 datefmt='%m-%d %H:%M',
 )
logging.debug('A debug message')
logging.info('Some information')
logging.warning('A shot across the bow')
def test():
 frame, filename, line_number, function_name, lines, index = \
 inspect.getouterframes(inspect.currentframe())[1]
 print(frame, filename, line_number, function_name, lines, index)
test()
# Should print the following (with current date/time of course)
# 10-19 19:57 INFO test.py:9 : Some information
# 10-19 19:57 WARNING test.py:10 : A shot across the bow
# (, 'C:/xxx/pyfunc/magic.py', 16, '', ['test()\n'], 0)

03.生成唯一ID


在有些情况下你需要生成一个唯一的字符串。我看到很多人使用md5()函数来达到此目的,但它确实不是以此为目的。

其实有一个名为uuid()的Python函数是用于这个目的的。

import uuid
result = uuid.uuid1()
print result
# output => various attempts
# 9e177ec0-65b6-11e3-b2d0-e4d53dfcf61b
# be57b880-65b6-11e3-a04d-e4d53dfcf61b
# c3b2b90f-65b6-11e3-8c86-e4d53dfcf61b

你可能会注意到,即使字符串是唯一的,但它们后边的几个字符看起来很相似。这是因为生成的字符串与电脑的MAC地址是相联系的。

为了减少重复的情况,你可以使用这两个函数。

import hmac, hashlib
key = '1'
data = 'a'
print hmac.new(key, data, hashlib.sha256).hexdigest()
m = hashlib.sha1()
m.update("The quick brown fox jumps over the lazy dog")
print m.hexdigest()
# c6e693d0b35805080632bc2469e1154a8d1072a86557778c27a01329630f8917
# 2fd4e1c67a2d28fced849ee1bb76e7391b93eb12

04.序列化


你曾经需要将一个复杂的变量存储在数据库或文本文件中吧?你不需要想一个奇特的方法将数组或对象格转化为式化字符串,因为Python已经提供了此功能。

import pickle
variable = ['hello', 42, [1, 'two'], 'apple']
# serialize content
file = open('serial.txt', 'w')
serialized_obj = pickle.dumps(variable)
file.write(serialized_obj)
file.close()
# unserialize to produce original content
target = open('serial.txt', 'r')
myObj = pickle.load(target)
print serialized_obj
print myObj
# output
# (lp0
# S'hello'
# p1
# aI42
# a(lp2
# I1
# aS'two'
# p3
# aaS'apple'
# p4
# a.
# ['hello', 42, [1, 'two'], 'apple']

这是一个原生的Python序列化方法。然而近几年来JSON变得流行起来,Python添加了对它的支持。现在你可以使用JSON来编解码。

import json
variable = ['hello', 42, [1, 'two'], 'apple']
print "Original {0} - {1}".format(variable, type(variable))
# encoding
encode = json.dumps(variable)
print "Encoded {0} - {1}".format(encode, type(encode))
# deccoding
decoded = json.loads(encode)
print "Decoded {0} - {1}".format(decoded, type(decoded))
# output
# Original ['hello', 42, [1, 'two'], 'apple'] - <type 'list'="">
# Encoded ["hello", 42, [1, "two"], "apple"] - <type 'str'="">
# Decoded [u'hello', 42, [1, u'two'], u'apple'] - <type 'list'="">

这样更紧凑,而且最重要的是与JavaScript和许多其他语言兼容。然而对于复杂的对象,其中的一些信息可能丢失。

05.压缩字符


当谈起压缩时我们通常想到文件,比如ZIP结构。在Python中也可以压缩长字符:

import zlib
string = """ Lorem ipsum dolor sit amet, consectetur
 adipiscing elit. Nunc ut elit id mi ultricies
 adipiscing. Nulla facilisi. Praesent pulvinar,
 sapien vel feugiat vestibulum, nulla dui pretium orci,
 non ultricies elit lacus quis ante. Lorem ipsum dolor
 sit amet, consectetur adipiscing elit. Aliquam
 pretium ullamcorper urna quis iaculis. Etiam ac massa
 sed turpis tempor luctus. Curabitur sed nibh eu elit
 mollis congue. Praesent ipsum diam, consectetur vitae
 ornare a, aliquam a nunc. In id magna pellentesque
 tellus posuere adipiscing. Sed non mi metus, at lacinia
 augue. Sed magna nisi, ornare in mollis in, mollis
 sed nunc. Etiam at justo in leo congue mollis.
 Nullam in neque eget metus hendrerit scelerisque
 eu non enim. Ut malesuada lacus eu nulla bibendum
 id euismod urna sodales. """
print "Original Size: {0}".format(len(string))
compressed = zlib.compress(string)
print "Compressed Size: {0}".format(len(compressed))
decompressed = zlib.decompress(compressed)
print "Decompressed Size: {0}".format(len(decompressed))
# output
# Original Size: 1022
# Compressed Size: 423
# Decompressed Size: 1022

06.注册Shutdown函数


有可模块叫atexit,它可以让你在脚本运行完后立马执行一些代码。

假如你想在脚本执行结束时测量一些基准数据,比如运行了多长时间:

import atexit
import time
import math
def microtime(get_as_float=False):
 if get_as_float:
 return time.time()
 else:
 return '%f %d' % math.modf(time.time())
start_time = microtime(False)
atexit.register(start_time)
def shutdown():
 global start_time
 print "Execution took: {0} seconds".format(start_time)
atexit.register(shutdown)
# Execution took: 0.297000 1387135607 seconds
# Error in atexit._run_exitfuncs:
# Traceback (most recent call last):
# File "C:\Python27\lib\atexit.py", line 24, in _run_exitfuncs
# func(*targs, **kargs)
# TypeError: 'str' object is not callable
# Error in sys.exitfunc:
# Traceback (most recent call last):
# File "C:\Python27\lib\atexit.py", line 24, in _run_exitfuncs
# func(*targs, **kargs)
# TypeError: 'str' object is not callable

打眼看来很简单。只需要将代码添加到脚本的最底层,它将在脚本结束前运行。但如果脚本中有一个致命错误或者脚本被用户终止,它可能就不运行了。

当你使用atexit.register()时,你的代码都将执行,不论脚本因为什么原因停止运行。

来源网络,侵权联系删除

私信我,回复:学习,获取免费学习资源包。

相关推荐

# Python 3 # Python 3字典Dictionary(1)

Python3字典字典是另一种可变容器模型,且可存储任意类型对象。字典的每个键值(key=>value)对用冒号(:)分割,每个对之间用逗号(,)分割,整个字典包括在花括号({})中,格式如...

Python第八课:数据类型中的字典及其函数与方法

Python3字典字典是另一种可变容器模型,且可存储任意类型对象。字典的每个键值...

Python中字典详解(python 中字典)

字典是Python中使用键进行索引的重要数据结构。它们是无序的项序列(键值对),这意味着顺序不被保留。键是不可变的。与列表一样,字典的值可以保存异构数据,即整数、浮点、字符串、NaN、布尔值、列表、数...

Python3.9又更新了:dict内置新功能,正式版十月见面

机器之心报道参与:一鸣、JaminPython3.8的热乎劲还没过去,Python就又双叒叕要更新了。近日,3.9版本的第四个alpha版已经开源。从文档中,我们可以看到官方透露的对dic...

Python3 基本数据类型详解(python三种基本数据类型)

文章来源:加米谷大数据Python中的变量不需要声明。每个变量在使用前都必须赋值,变量赋值以后该变量才会被创建。在Python中,变量就是变量,它没有类型,我们所说的"类型"是变...

一文掌握Python的字典(python字典用法大全)

字典是Python中最强大、最灵活的内置数据结构之一。它们允许存储键值对,从而实现高效的数据检索、操作和组织。本文深入探讨了字典,涵盖了它们的创建、操作和高级用法,以帮助中级Python开发...

超级完整|Python字典详解(python字典的方法或操作)

一、字典概述01字典的格式Python字典是一种可变容器模型,且可存储任意类型对象,如字符串、数字、元组等其他容器模型。字典的每个键值key=>value对用冒号:分割,每个对之间用逗号,...

Python3.9版本新特性:字典合并操作的详细解读

处于测试阶段的Python3.9版本中有一个新特性:我们在使用Python字典时,将能够编写出更可读、更紧凑的代码啦!Python版本你现在使用哪种版本的Python?3.7分?3.5分?还是2.7...

python 自学,字典3(一些例子)(python字典有哪些基本操作)

例子11;如何批量复制字典里的内容2;如何批量修改字典的内容3;如何批量修改字典里某些指定的内容...

Python3.9中的字典合并和更新,几乎影响了所有Python程序员

全文共2837字,预计学习时长9分钟Python3.9正在积极开发,并计划于今年10月发布。2月26日,开发团队发布了alpha4版本。该版本引入了新的合并(|)和更新(|=)运算符,这个新特性几乎...

Python3大字典:《Python3自学速查手册.pdf》限时下载中

最近有人会想了,2022了,想学Python晚不晚,学习python有前途吗?IT行业行业薪资高,发展前景好,是很多求职群里严重的香饽饽,而要进入这个高薪行业,也不是那么轻而易举的,拿信工专业的大学生...

python学习——字典(python字典基本操作)

字典Python的字典数据类型是基于hash散列算法实现的,采用键值对(key:value)的形式,根据key的值计算value的地址,具有非常快的查取和插入速度。但它是无序的,包含的元素个数不限,值...

324页清华教授撰写【Python 3 菜鸟查询手册】火了,小白入门字典

如何入门学习python...

Python3.9中的字典合并和更新,了解一下

全文共2837字,预计学习时长9分钟Python3.9正在积极开发,并计划于今年10月发布。2月26日,开发团队发布了alpha4版本。该版本引入了新的合并(|)和更新(|=)运算符,这个新特性几乎...

python3基础之字典(python中字典的基本操作)

字典和列表一样,也是python内置的一种数据结构。字典的结构如下图:列表用中括号[]把元素包起来,而字典是用大括号{}把元素包起来,只不过字典的每一个元素都包含键和值两部分。键和值是一一对应的...

取消回复欢迎 发表评论:

请填写验证码