Pydoc

pydoc是python自帶的一個(gè)文檔生成工具,使用pydoc可以很方便的查看類和方法結(jié)構(gòu),pydoc模塊可以從python代碼中獲取docstring,然后生成幫助信息。

pydoc是Python自帶的模塊,主要用于從python模塊中自動(dòng)生成文檔,這些文檔可以基于文本呈現(xiàn)的、也可以生成WEB頁面的,還可以在服務(wù)器上以瀏覽器的方式呈現(xiàn)!

python -m pydoc -p 1234 ? ??在本地機(jī)器上,按照給定的端口啟動(dòng)HTTP

一、查看文檔的方法

方法1:啟動(dòng)本地服務(wù),在web上查看文檔

python3 -m pydoc -p 1234

通過http://localhost:1234來訪問查看文檔

說明:

1、-p指定啟動(dòng)的服務(wù)的端口號(hào),可以隨意指定不沖突的端口號(hào)

2、只有在自建的工程根目錄下使用該命令,才能看到當(dāng)前工程下所有的內(nèi)容,否則只能看到python環(huán)境變量下的模塊內(nèi)容

3、如果本地只有一個(gè)python,可以直接使用【pydoc -p 端口號(hào)】啟動(dòng),但因?yàn)槲冶镜赜衟ython2和python3,所以指定了用python3

方法2:直接查看某個(gè)py文件的內(nèi)容

例子:新建了一個(gè)py文件叫做testpydoc.py,進(jìn)入testpydoc.py所在目錄

python3 -m pydoc testpydoc

方法三:生成html說明文檔

例子:新建了一個(gè)py文件叫做testpydoc.py,進(jìn)入testpydoc.py所在目錄

python3 -m pydoc -w?testpydoc

會(huì)默認(rèn)將當(dāng)前目錄下的testpydoc生成一個(gè)叫做testpydoc.html的文檔,如果是目錄直接【python3 -m pydoc -w 目錄名】生成文檔

說明:如果是將整個(gè)目錄生成這種格式,不建議用這種方式,因?yàn)槿绻故灸夸浵碌淖游募恼f明時(shí),會(huì)去子目錄下找對(duì)應(yīng).html文件,如果文件不存在,就會(huì)404

方法四:-k查找模塊

py通過-k查找模塊,會(huì)在當(dāng)前工程目錄以及python環(huán)境變量目錄下查找包含關(guān)鍵詞的模塊信息?

【python3 -m pydoc -k 關(guān)鍵詞】

例如如下命令:

python3 -m pydoc -k? testpydoc

結(jié)果如下:

testpydoc - @author 每天1990

二、html文檔說明?

通過查看文檔的方法,我們可以看到在html的文檔主要分成四部分:py文件的頂部注釋、Classes、Functions、Data

(示例代碼見結(jié)尾部分)

第一部分:模塊的文檔說明,展示模塊頂部的多行注釋

注釋內(nèi)如果包含了模塊文件內(nèi)的class名,或方法名(),則顯示藍(lán)色,且可以點(diǎn)擊跳轉(zhuǎn)到對(duì)應(yīng)說明位置

第二部分:classes,展示class以及class下的function

1.只能展示class下的注釋,不會(huì)展示class下方法的注釋

2.class上面有#注釋時(shí),展示#號(hào)的注釋

3.class下有”””多行注釋”””時(shí)優(yōu)先展示多行注釋,就不展示頂部的#號(hào)的注釋了

need-to-insert-img

第三部分:function,模塊下的def方法,不是class中的方法

1.function上面有#注釋時(shí),展示#號(hào)的注釋

2.function下有”””多行注釋”””時(shí)優(yōu)先展示多行注釋,就不展示頂部的#號(hào)的注釋了

第四部分:data,模塊下直接定義的變量,不是function或class的變量

示例代碼:

"""

@author?每天1990

@desc?本模塊是一個(gè)測(cè)試文件,用來說明pydoc的讀取內(nèi)容

@date?2017/4/13

說明:

classes:testclass(),具有function1()和function2()兩個(gè)方法

function:test1(),test2(),test3()

Data:a,b

"""

#注釋放在方法名前,使用#號(hào)注釋

def?test1(a):

print("注釋放在方法名前")

#注釋放在方法名前,使用#號(hào)注釋

def?test2():

"""

注釋放在方法內(nèi)的第一行,既有#號(hào)又有多行注釋時(shí),優(yōu)先展示多行注釋

"""

print("既有#號(hào)又有多行注釋時(shí),優(yōu)先展示多行注釋?")

def?test3():

#在方法第一行內(nèi)使用#注釋

print("在方法內(nèi)使用#號(hào)注釋,不生效")

class?testclass():

"""

注釋生效順序與方法一致,優(yōu)先展示類下的多行注釋,如果沒有才展示類上面的#號(hào)注釋

類下的方法的注釋不會(huì)展示出來

"""

def?function1(self):#類下方法的注釋不會(huì)展示

print("類下的第一個(gè)方法")

def?function2(self,a):

print("類下的第二個(gè)參數(shù),包含a參數(shù)")

a=1#變量的注釋不會(huì)展示出來

b=2

三、注釋方法

通過上面的文檔說明,我們可以合理的注釋,有助于了解工程結(jié)構(gòu)

python的注釋方法有兩種:

1.單行注釋:使用#號(hào)進(jìn)行注釋

#單行注釋

2.多行注釋:使用三個(gè)雙引號(hào)或單引號(hào)來注釋多行內(nèi)容

'''

單引號(hào)進(jìn)行多行注釋

'''

"""

雙引號(hào)進(jìn)行多行注釋

"""

pydoc注釋展示策略:

在functions和classes前面加#注釋,或者在function和class第一行內(nèi)加三個(gè)單引號(hào)或三個(gè)雙引號(hào)進(jìn)行注釋

如果有三個(gè)引號(hào)的注釋方法,會(huì)優(yōu)先使用三個(gè)點(diǎn)的注釋,其次才展示#號(hào)的注釋

注意:如果在方法或class定義后第一行使用#注釋是拉取不到注釋的

例子1:class前有#號(hào)注釋,class內(nèi)有多行注釋,pydoc會(huì)優(yōu)先展示三個(gè)點(diǎn)內(nèi)的注釋


例子2:方法內(nèi)使用#號(hào)注釋,pydoc不會(huì)顯示注釋內(nèi)容(class同理)

例子3:方法或class沒有多行注釋,只在方法外有#號(hào)注釋時(shí),會(huì)展示定義前的#號(hào)內(nèi)的內(nèi)容

例子4:模塊頂部的內(nèi)容,優(yōu)先展示多行注釋中的內(nèi)容

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 模塊和包 一 模塊 1 什么是模塊? 常見的場(chǎng)景:一個(gè)模塊就是一個(gè)包含了python定義和聲明的文件,文件名就是...
    go以恒閱讀 2,344評(píng)論 0 4
  • 包(lib)、模塊(module) 在Python中,存在包和模塊兩個(gè)常見概念。 模塊:編寫Python代碼的py...
    清清子衿木子水心閱讀 3,907評(píng)論 0 27
  • 近期在做一個(gè)團(tuán)隊(duì)項(xiàng)目,產(chǎn)生大量的函數(shù)與類,不好查找也不好團(tuán)隊(duì)使用,最原生的python代碼文檔格式查閱困難,所以就...
    綿延三生三世閱讀 791評(píng)論 0 1
  • 章小慧拎著袋子跟著周斌上了火車,她要給他送行。袋子里有水果、八寶粥、面包,還有其它吃喝的東西,這都是章小慧特意從超...
    麥兜爸比閱讀 420評(píng)論 0 6
  • 一家面館,如果菜色和味道都平平無奇,卻獲眾人交口稱贊,那么我便會(huì)對(duì)其懷疑,他的菜里是不是加了太多的味精,以致于麻痹...
    林帥閱讀 422評(píng)論 0 1

友情鏈接更多精彩內(nèi)容