偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

這些Python高效率技巧,一般人都不會(huì)!

開發(fā) 后端
你估計(jì)已經(jīng)看了不少關(guān)于 Python 技巧的文章,里面可能會(huì)提到變量拆包(unpacking)、局部函數(shù)等,但是 Python 還有很多不為人知的高效用法,等待著被人發(fā)現(xiàn)。本文將介紹作者縱觀全網(wǎng)之后,都屬于很少?zèng)]提及的技巧。

[[285806]]

你估計(jì)已經(jīng)看了不少關(guān)于 Python 技巧的文章,里面可能會(huì)提到變量拆包(unpacking)、局部函數(shù)等,但是 Python 還有很多不為人知的高效用法,等待著被人發(fā)現(xiàn)。本文將介紹作者縱觀全網(wǎng)之后,都屬于很少?zèng)]提及的技巧。

清理字符串輸入

清理用戶輸入的問題,幾乎適用于我們可能編寫的每個(gè)程序。通常將字符轉(zhuǎn)換為小寫或大寫就足夠了,這時(shí)只需要使用正則即可,但是對于復(fù)雜的情況,有一種更好的方法:   

  1. user_input = "This\nstring has\tsome whitespaces...\r\n"  
  2.     character_map = {  
  3.         ord('\n') : ' ',  
  4.         ord('\t') : ' ',  
  5.         ord('\r') : None  
  6.     } 
  7.      user_input.translate(character_map)  # This string has some whitespaces... " 

在上述示例中,可以看到空格符“ \ n”和“ \ t”已被單個(gè)空格替換,而“ \ r”已被完全刪除。這是一個(gè)簡單的示例,但是我們可以更進(jìn)一步,使用 unicodedata包及其 combining()函數(shù)生成范圍更廣的映射表,從字符串中刪除所有重音符號(hào)。

迭代器切片

如果您嘗試獲取迭代器的切片,系統(tǒng)會(huì)報(bào) TypeError,提示生成器對象不可下標(biāo),但是解決方案很簡單: 

  1. import itertools  
  2.  s = itertools.islice(range(50), 10, 20)  # <itertools.islice object at 0x7f70fab88138>  
  3.  for val in s:  
  4.  ... 

使用 itertools.islice,我們可以創(chuàng)建一個(gè) islice對象,該對象是產(chǎn)生所需元素的迭代器。不過,請務(wù)必注意,這會(huì)消耗所有生成器項(xiàng),直到切片開始為止,而且還會(huì)消耗我們的“ islice”對象中的所有項(xiàng)。

Using itertools.islice we can create a islice object which is an iterator that produces desired items. It's important to note though, that this consumes all generator items up until the start of slice and also all the items in our islice object.

跳過可迭代對象的開始

有時(shí)候需要處理的文件里,明確存在一些不需要的數(shù)據(jù)行,但是我們不確定數(shù)量,比如說代碼中的注釋。這時(shí), itertools 再次為我們提供了簡潔的方案:   

  1. string_from_file = "" 
  2.    // Author: ...  
  3.    // License: ...  
  4.    //  
  5.    // Date: ...  
  6.    Actual content...  
  7.    """  
  8.    import itertools  
  9.    for line in itertools.dropwhile(lambda line: line.startswith("//"), string_from_file.split("\n")):  
  10.    print(line) 

這段代碼僅在初始注釋部分之后,才會(huì)產(chǎn)生數(shù)據(jù)行。如果我們只想在迭代器的開頭丟棄數(shù)據(jù),而又不知道有具體數(shù)量時(shí),這個(gè)方法很有用。

僅帶關(guān)鍵字參數(shù)(kwargs)的函數(shù)

有時(shí)候,使用僅支持關(guān)鍵字參數(shù)的函數(shù)可以讓代碼更加清晰易懂:   

  1. def test(*, a, b):  
  2.    pass  
  3.    test("value for a", "value for b")  # TypeError: test() takes 0 positional arguments...  
  4.    test(a="value"b="value 2")  # Works... 

只需要在關(guān)鍵字參數(shù)前面再加一個(gè) * 參數(shù),就可以輕松實(shí)現(xiàn)了。當(dāng)然,如果還希望再加上位置參數(shù),可以在 * 參數(shù)前面再增加。

創(chuàng)建支持 with語句的對象

我們都知道如何打開文件或使用 with語句獲取鎖,但是怎樣自己可以實(shí)現(xiàn)類似的功能呢?一般來說,我們可以使用 __enter__和 __exit__方法來實(shí)現(xiàn)上下文管理器協(xié)議:   

  1. classConnection:  
  2.    def __init__(self):  
  3.    ...  
  4.    def __enter__(self):  
  5.    # Initialize connection...  
  6.    def __exit__(self, type, value, traceback):  
  7.    # Close connection...  
  8.    withConnection() as c:  
  9.    # __enter__() executes  
  10.    ...  
  11.    # conn.__exit__() executes 

上面是最常見的實(shí)現(xiàn)方式,但是還有一種更簡單的方法:   

  1. from contextlib import contextmanager  
  2.    @contextmanager  
  3.    def tag(name):  
  4.    print(f"<{name}>")  
  5.    yield  
  6.    print(f"")  
  7.    with tag("h1"):  
  8.    print("This is Title.") 

上面的代碼段使用 contextmanager管理器裝飾器實(shí)現(xiàn)了內(nèi)容管理協(xié)議。進(jìn)入“ with”塊時(shí),執(zhí)行“ tag”函數(shù)的第一部分(在“ yield”之前),然后執(zhí)行 yield,最后執(zhí)行其余部分。

用 __slots__節(jié)省內(nèi)存

如果程序需要?jiǎng)?chuàng)建大量的類實(shí)例,我們會(huì)發(fā)現(xiàn)程序占用了大量內(nèi)存。這是因?yàn)?Python 使用字典來表示類實(shí)例的屬性,這樣的話創(chuàng)建速度很快,但是很耗內(nèi)存。如果內(nèi)存是你需要考慮的一個(gè)問題,那么可以考慮使用 __slots__:   

  1. classPerson:  
  2.        __slots__ = ["first_name", "last_name", "phone"]  
  3.    def __init__(self, first_name, last_name, phone):  
  4.    self.first_name = first_name  
  5.    self.last_name = last_name  
  6.    self.phone = phone 

當(dāng)我們定義 __slots__屬性時(shí),Python會(huì)使用固定大小的數(shù)組(占用內(nèi)存少)來存儲(chǔ)屬性,而不是字典,這大大減少了每個(gè)實(shí)例所需的內(nèi)存。不過使用 __slots__還有一些缺點(diǎn):無法聲明任何新屬性,我們只能使用 __slots__中的那些屬性。同樣,帶有 __slots__的類不能使用多重繼承。

限制CPU和內(nèi)存使用量

如果不是想優(yōu)化程序內(nèi)存或CPU使用率,而是想直接將其限制為某個(gè)數(shù)值,那么Python也有一個(gè)可以滿足要求的庫:   

  1. import signal  
  2.     import resource  
  3.     import os  
  4.     # To Limit CPU time  
  5.     def time_exceeded(signo, frame):  
  6.     print("CPU exceeded...")  
  7.     raiseSystemExit(1)  
  8.     def set_max_runtime(seconds):  
  9.     # Install the signal handler and set a resource limit  
  10.         soft, hard = resource.getrlimit(resource.RLIMIT_CPU)  
  11.         resource.setrlimit(resource.RLIMIT_CPU, (seconds, hard))  
  12.         signal.signal(signal.SIGXCPU, time_exceeded)  
  13.     # To limit memory usage  
  14.     def set_max_memory(size):  
  15.         soft, hard = resource.getrlimit(resource.RLIMIT_AS)  
  16.         resource.setrlimit(resource.RLIMIT_AS, (size, hard)) 

在這里,我們可以設(shè)置了最大cpu運(yùn)行時(shí)間以及最大內(nèi)存使用限制的兩個(gè)選項(xiàng)。對于cpu限制,我們首先獲得該特定資源( RLIMIT_CPU)的軟限制和硬限制,然后使用參數(shù)指定的秒數(shù)和先前獲取的硬限制來設(shè)置。

最后,我們注冊了一個(gè)在超過CPU時(shí)間后,讓系統(tǒng)退出的信號(hào)。至于內(nèi)存,我們再次獲取軟限制和硬限制,并使用帶有大小參數(shù)的 setrlimit和硬限制完成配置

控制導(dǎo)入的內(nèi)容

某些語言提供了導(dǎo)出成員(變量,方法,接口)的顯式機(jī)制,例如Golang,它僅導(dǎo)出以大寫字母開頭的成員。但是在Python中,所有對象都會(huì)導(dǎo)出,除非我們使用 __all__:   

  1. def foo():  
  2.    pass  
  3.    def bar():  
  4.    pass  
  5.    __all__ = ["bar"] 

上面的代碼段中,只會(huì)導(dǎo)出 bar函數(shù)。另外,如果 __all__的值為空,那么不會(huì)導(dǎo)出任何函數(shù),而且在導(dǎo)入該模塊時(shí)系統(tǒng)會(huì)報(bào) AttributeError。

實(shí)現(xiàn)比較運(yùn)算符

如果我們要逐一為某個(gè)類實(shí)現(xiàn)所有的比較運(yùn)算符,你肯定會(huì)覺得很麻煩,因?yàn)橐獙?shí)現(xiàn)的方法還不少,有 __lt__,__le__,__gt__, 和 __ge__。 

其實(shí),Python 提供了一種便捷的實(shí)現(xiàn)方式,就是通過 functools.total_ordering裝飾器。   

  1. from functools import total_ordering  
  2.    @total_ordering  
  3.    classNumber:  
  4.    def __init__(self, value):  
  5.    self.value = value  
  6.    def __lt__(self, other):  
  7.    returnself.value < other.value  
  8.    def __eq__(self, other):  
  9.    returnself.value == other.value  
  10.    print(Number(20) > Number(3))  
  11.    print(Number(1) < Number(5))  
  12.    print(Number(15) >= Number(15))  
  13.    print(Number(10) <= Number(2)) 

這是怎么實(shí)現(xiàn)的呢? total_ordering可以用來簡化實(shí)現(xiàn)類排序的過程。我們只需要定義 __lt__和 __eq__(這是映射剩余操作的最低要求),然后就交給裝飾器去完成剩余的工作了。

結(jié)語

在日常Python編程時(shí),上述特性并非都是必不可少的和有用的,但是其中某些功能可能會(huì)不時(shí)派上用場,并能簡化冗長且令人討厭的任務(wù)。

還要指出的是,所有這些功能都是Python標(biāo)準(zhǔn)庫的一部分,而在我看來,其中一些功能似乎不像是應(yīng)該在標(biāo)準(zhǔn)庫中的功能。

因此,每當(dāng)你決定要用Python實(shí)現(xiàn)某些功能時(shí),都請先在標(biāo)準(zhǔn)庫中找一找,如果找不到合適的庫,那么可能是因?yàn)椴檎业淖藙莶粚?。而且即使?biāo)準(zhǔn)庫里沒有,有很大的概率已經(jīng)存在一個(gè)第三方庫了! 

 

責(zé)任編輯:龐桂玉 來源: Python之禪
相關(guān)推薦

2018-01-25 09:15:16

機(jī)房機(jī)柜走線

2017-07-21 11:12:51

跳線裝機(jī)技巧

2015-03-16 11:33:16

程序員代碼bug

2020-03-23 08:36:18

Python編程代碼

2021-12-14 10:55:14

Python元素數(shù)據(jù)

2016-12-29 11:41:45

2019-07-22 06:33:55

R語言編程函數(shù)

2021-04-20 09:55:37

Linux 開源操作系統(tǒng)

2015-06-24 10:01:47

2022-03-27 22:07:35

元宇宙虛擬人IBM

2023-05-16 07:15:11

架構(gòu)模型對象

2018-09-30 14:46:38

Linux命令技巧

2015-11-27 12:59:11

Android技巧提高效率

2010-08-19 10:18:02

寬帶路由器

2018-06-28 12:47:30

2010-11-17 15:55:31

VMware虛擬機(jī)

2010-01-04 09:40:12

雙i7服務(wù)器主板

2023-10-23 15:02:53

JavaScript

2021-01-14 07:46:08

Windows 7微軟操作系統(tǒng)

2025-01-15 17:00:00

開發(fā)Linux命令
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)