色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

構建Python庫API有用的建議清單

馬哥Linux運維 ? 來源:未知 ? 作者:李倩 ? 2018-05-02 14:58 ? 次閱讀

本篇文章基于 2017 PyCon 大會上的演講:How to make a good library API。列出對于構建 Python 庫 API 有用的建議清單。

簡潔性

在 README 文件中寫入簡單的客戶端代碼。例如:Pendulum 的 README文件就是以簡單的用戶代碼開始的。

減少冗余的代碼:數一數從第一行開始到你真正調用 API 函數的行數。例如: 與 Request 庫相比,進行 HTTP 請求時 urllib2 庫就很多的冗余代碼。

使用案例例如: 這個網頁展示的內容:https://python-social-auth-docs.readthedocs.io/en/latest/use_cases.html

在實踐中逐步完善:實用且明智的缺省值設置

- 具有缺省設置,并根據最常用的使用情況來設置缺省值。

-設置參數位置,將最常用的參數放在前面,將相似的放在一起。例如: JavaScript 的history.pushState函數的默認參數順序是:state, title, URL。然而很多用戶僅僅想要將 URL 添加進歷史值中,但是實際的情況卻迫使他們不得不設置 state 與 title 參數的值。

不要將源代碼片段復制粘貼進你的 API 中。

避免麻煩的輸入:- 檢查是否存在參數名歧義的情況。例如在 Scrapy 1.2 中,send 方法有一個to參數,接收的是字符串列表。如果用戶傳入一個字符串,這個方法就會遍歷這個字符串,并將每個字符當做一個郵箱地址并發送郵件。在 Scrapy 1.3 中則修改了這個 Bug,修改后即可以接收字符串,也可以接收字符串列表。- 檢測是否只是為了調用 API 就實例化某些東西的情況。如果存在,可以考慮接收封裝值。例如:對于一個僅接受類文件對象的函數,如果用戶想要調用它,就不得不使用 StringIO模塊。- 檢查是否可以使用內置類型來替換自定義類型。或者兩者都支持使用。

堅持最小驚訝原則( Principle of least astonishment):如果一個函數特征很讓人吃驚,或許就應該考慮重新設計它了。- 程序默認的行為是用戶所期望的嗎?- 程序默認的行為是否符合用戶對于程序性能、副作用,安全性,可靠性,安全性以及限制條件的要求?

要做到抽象- 讓用戶不需要關心問題是怎么解決的,而是關心要解決什么問題。 例如: 為了完成一個簡單的工作,項目開發人員不必過于在意任務序列、消息破壞,序列化等操作,他們只需要使用 @aap.task 這樣一個裝飾器即可。 API 關注的是任務的定義而不是完成任務的過程。- 檢查 API 中是否包含了不應該有的東西,牢記,要小心所謂的“抽象漏洞定理”( The Law of Leaky Abstractions)。例如: RPC(remote procedure call)就是一個很好的反面教材,因為它將遠程資源當做了本地資源進行抽象處理,但實際上遠程資源的處理不同于本地資源。

像點 Python 的樣子- 努力向常見的 Python 習俗靠近,使你的 API 調用看起來就跟 Python 內置的 API 一樣。 例如在 Python2 中,ConfigParser.get 接受一個 section 參數和一個 option 參數。但是這個并不符合 Python 習俗,在 Python 的字典(dict)對象的 get 方法中,我們接受的是 key 參數 和一個缺省參數。 在 Python3 中,這個問題得以修復,此函數的參數輸入就類似字典那樣了。

一致性

命名問題:你 API 中的命名是否和 Python 的習俗保持了一致性? 我們命名應該與 PEP8 中所給出一致。PEP8 是 Python 官方的代碼風格指南。為了保持命名與代碼風格的一致性,建議使用 flake8 來規范你的 API 代碼。

命名問題:API 中的命名是否一致?- 術語的順序:string_encodeVSdecode_string- 縮寫問題:activate_prevVSfetch_previous以及bin2hex VS strtolower- 是否帶有下劃線:gettypeVSget_class- 單復數問題:values_list VSvalue_list- 正負問題:button.enabled == TrueVSbutton.disabled == True

空值問題:在空值意義的定義是否一致?目前的是最好的選擇嗎?- 決定下面哪個代表了空值:None、False、[]、''、0- 小心一些出人意料的值:bool(datetime.time(0)) == False在Python3.5以前是這樣

參數問題:在參數的順序上是否具有一致性?例如:datetime.datetime(year, month, day, minute, second, microsecond)vsdatetime.timedelta(days, seconds, microseconds, milliseconds, minutes, hours, weeks)

行為問題:在相似或者不同的行為上是否具有一致性?行為的不對稱應該反應在格式的不對稱上。例如,numbers.sort()VSsort(numbers)

靈活性

減小整體的不連續性- 檢查所有的類的功能是否單一職責?如果不是,就應該把那些類拆解開來。例如,一個從緩存中獲取數據的類應該將其連接緩存服務器的步驟交給另一個類做。

- 檢查函數的名稱中是否包含了`and`或者是否包含多個操作。 如果確實如此,應該將這個函數拆成多個不同的函數。但是,如果這個函數經常被調用,那么可以保留一個結合了眾多函數的函數。例如:print_formatted函數可以被拆解為兩個函數:print和formated

- 檢查是否存在用戶復制粘貼代碼以改變函數功能的行為。 應該提供代碼重構,回調功能。

- 檢查在函數內部是否使用了屬性值,如果有可以使用 get_something 方法代替。例如在 Djando 的 REST 框架中, CursorPagination 這個類僅僅支持一個固定大小的屬性值:page_size,其原因就是這個類沒有get_page_size這個方法。 這個問題再后來就通過上述方法解決了,即添加了 get_page_size方法。

- 盡量避免隱藏可能有用的參數。例如我們的 API 中調用了另一個低級的 API 但是卻沒有展示這個低級 API 的參數情況

- 返回用戶可能需要的一切信息

- 用戶調用 API 時,要處理用戶可能需要所有情況

- 在進行 API 測試的時候要測試每一個mock.pathch。 雖然在程序運行的時候有一些東西不容易修改,但我們可以通過設置參數來修改某些東西。例如,Python 的內置函數sched.scheduler接受兩個參數timefunc和delayfunc。而我們沒必要對time.monotonic和time.sleep兩個函數進行 mock 測試,用戶會根據自己的需求進行相應的改變。

建立抽象- 按照底層實現的結構,去封裝我們的函數成員與對象。例如 Beautiful Soup 就為多個分析器設計了同樣的 API 結構。

- 提供多級的抽象結構,從最簡單到最個性化。例如, Celery 既提供了@app.task這個裝飾器,又提供了個性化的 task 類,而這個類繼承于celery.Task

- 提供擺脫封裝的方法,讓用戶可以直接使用被抽象的資源和能力。例如,Django 的查詢集合支持使用.extra方法將自定義的 SQL 與 ORM 進行結合來產生查詢語句,同時也支持使用.raw來直接使用原生的 SQL 查詢語句。

- 將底層實現中常見的錯誤進行封裝,避免給用戶直接報錯。例如當 API 支持多個數據引擎的時候,出現數據庫連接錯誤時,其顯示信息應該一樣。這個幫助用戶找出問題所在,并且在修改數據庫引擎時不會需要修改很多代碼。

要有 Python 范- 對于獲取(get)和 設置(set)操作使用 Python 的自帶屬性- 對于運算符重載要使用魔法方法(magic method)- 對于簡單的調試,使用__repr__魔法方法- 對于包含 打開-關閉 或者 開始-結束 這樣的包含生命周期的問題,使用 with 語句- 對于容易組合共同行為或者登記某些東西使用裝飾器- 對于迭代使用迭代器- 對于復雜的邏輯問題使用生成器- 對異步問題使用 asyncio- 盡量使用內置的集合- 對于簡單的控制反演使用簡單的高級函數,例如在list.sort函數中接受key參數作為等級高低計算函數以便計算列表的順序。- 對于復雜的流程問題,可以按照 函數/類的管道、繼承、生成器的順序逐一考慮。例如 管道問題可參考:python-social-auth 管道;繼承問題可參考: Django 的類; 生成器問題可參考: Scrapy 的爬蟲程序。- 尊重鴨子式編程風格,要求諒解比諒解本身更加容易

國際化終端用戶看到的字符串。

安全性

檢查文檔中的用于描述函數功能的警告性字眼,例如: warning,careful,remember to, dont't forget。如果存在這些字眼,就得考慮如何更改代碼使得函數更加安全穩定。

檢查常見的錯誤,使用 Python 內置的 warning 模塊來記錄警告

明確不安全的行為。例如如果一些變量沒有設置值,不要特意為它設置。不要到處寫 fileds = None 這樣的語句。

不要通過對象名稱或者模塊名稱來隱式地鏈接代碼,使用一個注冊函數或者注冊裝飾器。例如 Django-admin 的注冊問題不僅支持通過函數也支持裝飾器。

不要依賴方法的調用順序,盡量使用 with 語句。

快速報錯: 程序出錯就直接退出并不是 Python 式的思維

- 當一個庫函數接受到一個無效的具有錯誤格式或者錯誤表達的參數,例如參數溢出,就產生一個 Value Error 錯誤。- 當一個庫函數接受到一個不兼容類型的數據便產生一個 TypeError 錯誤,例如 duck 類型并不兼容 quack 類型。 不要在 if isinstance(duck, LibDuck) 或者 if type(duck) == LibDuck) 這樣的語句中引發異常。首先嘗試使用 quack,如果錯誤則引發 TypeError 異常,并打印明確的錯誤信息。

總結我的 API 旨在將簡單的事情變的簡潔,將復雜的事情變為現實,將錯誤的事情永遠杜絕。

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • API
    API
    +關注

    關注

    2

    文章

    1505

    瀏覽量

    62194
  • python
    +關注

    關注

    56

    文章

    4800

    瀏覽量

    84843
  • 函數庫
    +關注

    關注

    1

    文章

    84

    瀏覽量

    32442

原文標題:Python 函數庫 APIs 編寫指南

文章出處:【微信號:magedu-Linux,微信公眾號:馬哥Linux運維】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    如何利用pythonAPI查詢IP地址?

    Python中,直接查詢IP地址的地理位置或詳細信息(如所屬國家、城市等)通常需要依賴外部API服務,因為Python標準本身不提供直接查詢IP地址地理位置的功能。以下是一個使用r
    發表于 08-28 11:55

    2017年10大Python總結

    目的,需要一個精通Javascript的專職前端團隊來搭建GUI,以后就用不著啦。今年發布的Dash是在純Python環境中構建數據可視化Web APP的開源。該基于Flask、P
    發表于 01-23 14:48

    Python機器學習常用

    歡迎的編程語言!人工智能是當前最熱門話題之一,機器學習技術是人工智能實現必備技能,Python編程語言含有最有用的機器學習工具和,以下是Python開發工程師必知的十大機器學習
    發表于 03-26 16:29

    建議收藏】Python大全

    的封裝(需要PyQT),Splinter -通用API瀏覽器模擬器(seleniumweb驅動,Django客戶 端,Zope) 。多重處理threading - Python標準的線程運行。對于I/0
    發表于 09-06 15:58

    如何使用Python包裝器正確構建OpenVINO工具套件

    構建該工具套件。 如果您未明確指定 Python 版本,CMake 會選擇系統級 Python 版本(2.7),而且您的 Python 腳本將不起作用。 注意以下說明假定您已安裝了
    發表于 08-15 07:13

    Python應用與優化所必備的6個基本

    無論你是想快速入手Python還是想為Python應用程序構建本地UI,亦或者對Python代碼進行優化,本文列舉的6個,都有可能會幫到你
    發表于 11-15 11:40 ?2743次閱讀

    python代碼示例之基于Python的日歷api調用代碼實例

    本文檔的主要內容詳細介紹的是python代碼示例之基于Python的日歷api調用代碼實例。
    發表于 09-06 14:25 ?42次下載
    <b class='flag-5'>python</b>代碼示例之基于<b class='flag-5'>Python</b>的日歷<b class='flag-5'>api</b>調用代碼實例

    ADM1266 Linux APIPython簡介

    ADM1266 Linux APIPython簡介
    發表于 05-17 10:50 ?6次下載
    ADM1266 Linux <b class='flag-5'>API</b>和<b class='flag-5'>Python</b><b class='flag-5'>庫</b>簡介

    90條關于寫Python 程序的建議

    python,希望這篇文章對你有用。 1. 首先 建議1、理解Pythonic概念—-詳見Python中的《Python之禪》
    的頭像 發表于 05-31 10:12 ?1523次閱讀

    基于python的用于構建仿真及測試用例的libcocotb

    and Verilog testbenches in Python.?? ????? 21世紀,python成了一門吃香的語言。cocotb是一套基于python的用于構建仿真及測試
    的頭像 發表于 10-13 17:01 ?6809次閱讀
    基于<b class='flag-5'>python</b>的用于<b class='flag-5'>構建</b>仿真及測試用例的lib<b class='flag-5'>庫</b>cocotb

    ChatGPT API調用python和腳本實現

    Chat GPT 由于其獨特、近乎準確且類似人類的響應,如今在互聯網上引起了過多的討論。本文討論如何通過 Python 代碼連接到 Chat GPT API。如果需要用 website訪問
    發表于 02-14 10:13 ?0次下載
    ChatGPT <b class='flag-5'>API</b>調用<b class='flag-5'>python</b>和腳本實現

    python讀取數據數據 python查詢數據 python數據連接

    python讀取數據數據 python查詢數據 python數據連接
    的頭像 發表于 08-28 17:09 ?1855次閱讀

    Python中oloredlogs的使用

    于長時間運行的應用程序或者需要詳細查看日志信息的情況非常有用。 coloredlogs的使用 1.安裝coloredlogs 在使用前我們需要在Python中下載它 pip install
    的頭像 發表于 10-07 11:28 ?857次閱讀
    <b class='flag-5'>Python</b><b class='flag-5'>庫</b>中oloredlogs的使用

    Bulbea:用于股票市場預測和建模的Python

    Bulbea 是一個基于深度學習開發的,用于股票市場預測和建模的Python。 Bulbea 自帶了不少可用于股票深度學習訓練及測試的API,并且易于對數據進行擴展和延申,構建屬于我
    的頭像 發表于 10-17 11:01 ?530次閱讀
    Bulbea:用于股票市場預測和建模的<b class='flag-5'>Python</b><b class='flag-5'>庫</b>

    如何使用Python構建LSTM神經網絡模型

    構建一個LSTM(長短期記憶)神經網絡模型是一個涉及多個步驟的過程。以下是使用Python和Keras構建LSTM模型的指南。 1. 安裝必要的
    的頭像 發表于 11-13 10:10 ?465次閱讀
    主站蜘蛛池模板: 果冻传媒mv国产陈若瑶主演| 久久伊人天堂视频网| 久久中文字幕免费高清| 亚洲精品九色在线网站| 国产内射AV徐夜夜| 桃色园社区| 国产欧美另类久久久精品免费| 视频一区在线免费观看| 成人国产AV精品久久久久| 漂亮美女2018完整版| a视频在线免费观看| 免费国产久久拍久久爱| 97色伦97色伦国产| 欧美美女论坛| 成年私人影院网站在线看| 三级成人电彭| 国产睡熟迷奷系列网站| 亚洲免费福利在线视频| 久久精品无码人妻无码AV蜜臀| 在线播放午夜理论片| 久久亚洲国产中文字幕| 99在线观看视频| 色婷婷AV99XX| 国产专区青青在线视频| 一区二区视频在线观看高清视频在线| 精品四虎国产在免费观看| 在线观看qvod| 欧美牲交视频免费观看K8经典| 第一次破女初国产美女| 性生生活大片又黄又| 久久丫线这里只精品| xxnxx美女| 亚洲a免费| 免费女人光着全身网站| 高中生被C到爽哭视频免费| 亚洲乱码中文字幕久久| 免费观看视频成人国产| 国产 日韩 欧美 综合 激情| 亚洲精品伊人久久久久| 末班车动漫无删减免费| 攻把受做得合不拢腿play|