新聞中心
IDLE
源代碼: Lib/idlelib/

創(chuàng)新互聯(lián)公司從2013年成立,是專業(yè)互聯(lián)網(wǎng)技術(shù)服務(wù)公司,擁有項(xiàng)目網(wǎng)站制作、做網(wǎng)站網(wǎng)站策劃,項(xiàng)目實(shí)施與項(xiàng)目整合能力。我們以讓每一個(gè)夢(mèng)想脫穎而出為使命,1280元寧津做網(wǎng)站,已為上家服務(wù),為寧津各地企業(yè)和個(gè)人服務(wù),聯(lián)系電話:18980820575
IDLE 是 python 所內(nèi)置的開發(fā)與學(xué)習(xí)環(huán)境。
IDLE 具有以下特性:
-
編碼于 100% 純正的 Python,使用名為 tkinter 的圖形用戶界面工具
-
跨平臺(tái):在 Windows、Unix 和 macOS 上工作近似。
-
提供輸入輸出高亮和錯(cuò)誤信息的 Python 命令行窗口 (交互解釋器)
-
提供多次撤銷操作、Python 語法高亮、智能縮進(jìn)、函數(shù)調(diào)用提示、自動(dòng)補(bǔ)全等功能的多窗口文本編輯器
-
在多個(gè)窗口中檢索,在編輯器中替換文本,以及在多個(gè)文件中檢索(通過 grep)
-
提供持久保存的斷點(diǎn)調(diào)試、單步調(diào)試、查看本地和全局命名空間功能的調(diào)試器
-
配置、瀏覽以及其它對(duì)話框
目錄
IDEL 有兩種主要的窗口類型:Shell窗口和編輯器窗口。其中編輯器窗口可以同時(shí)打開多個(gè)。并且對(duì)于 Windows 和 Linux 平臺(tái),窗口頂部主菜單各不相同。以下每個(gè)菜單說明項(xiàng),都標(biāo)識(shí)了與之關(guān)聯(lián)的平臺(tái)類型。
導(dǎo)出窗口,例如使用 編輯=>在文件中查找 是編輯器窗口的的一個(gè)子類型。它們目前有著相同的主菜單,但是默認(rèn)標(biāo)題和上下文菜單不同。
在macOS上,只有一個(gè)應(yīng)用程序菜單。它會(huì)根據(jù)當(dāng)前選擇的窗口動(dòng)態(tài)變化。它具有一個(gè)IDLE菜單,并且下面描述的某些條目已移動(dòng)到符合Apple準(zhǔn)則的位置。
文件菜單 (命令行和編輯器)
新建文件
創(chuàng)建一個(gè)文件編輯器窗口。
打開…
使用打開窗口以打開一個(gè)已存在的文件。
打開模塊…
打開一個(gè)已存在的模塊 (搜索 sys.path)
近期文件
打開一個(gè)近期文件列表,選取一個(gè)以打開它。
Module Browser
于當(dāng)前所編輯的文件中使用樹形結(jié)構(gòu)展示函數(shù)、類以及方法。在命令行中,首先打開一個(gè)模塊。
路徑瀏覽
在樹狀結(jié)構(gòu)中展示 sys.path 目錄、模塊、函數(shù)、類和方法。
保存
如果文件已經(jīng)存在,則將當(dāng)前窗口保存至對(duì)應(yīng)的文件。自打開或上次保存之后經(jīng)過修改的文件的窗口標(biāo)題欄首尾將出現(xiàn)星號(hào) * 。如果沒有對(duì)應(yīng)的文件,則使用“另存為”代替。
保存為…
Save the current window with a Save As dialog. The file saved becomes the new associated file for the window. (If your file namager is set to hide extensions, the current extension will be omitted in the file name box. If the new filename has no ‘.’, ‘.py’ and ‘.txt’ will be added for Python and text files, except that on macOS Aqua,’.py’ is added for all files.)
另存為副本…
Save the current window to different file without changing the associated file. (See Save As note above about filename extensions.)
打印窗口
通過默認(rèn)打印機(jī)打印當(dāng)前窗口。
關(guān)閉窗口
關(guān)閉當(dāng)前窗口(如果是未保存的編輯器窗口,則會(huì)提示保存;如果是未保存的 Shell 窗口,則會(huì)提示退出執(zhí)行)。 在Shell 窗口中調(diào)用 exit() 或 close() 也會(huì)關(guān)閉 Shell 窗口。 如果這是唯一的窗口,則還會(huì)退出 IDLE。
退出 IDLE
關(guān)閉所有窗口并退出 IDLE (將提示保存未保存的編輯窗口)。
編輯菜單(命令行和編輯器)
撤銷操作
撤銷當(dāng)前窗口的最近一次操作。最高可以撤回 1000 條操作記錄。
重做
重做當(dāng)前窗口最近一次所撤銷的操作。
全選
選擇當(dāng)前窗口的全部?jī)?nèi)容。
剪切
復(fù)制選區(qū)至系統(tǒng)剪貼板,然后刪除選區(qū)。
復(fù)制
復(fù)制選區(qū)至系統(tǒng)剪貼板。
粘貼
插入系統(tǒng)剪貼板的內(nèi)容至當(dāng)前窗口。
剪貼板功能也可用于上下文目錄。
查找…
打開一個(gè)提供多選項(xiàng)的查找窗口。
再次查找
重復(fù)上一次搜索(如果有的話)。
查找選區(qū)
查找當(dāng)前選中的字符串,如果存在
在文件中查找…
打開文件查找對(duì)話框。將結(jié)果輸出至新的輸出窗口。
替換…
打開 查找并替換 對(duì)話框。
前往行
將光標(biāo)移到所請(qǐng)求行的開頭并使該行可見。 對(duì)于超過文件尾的請(qǐng)求將會(huì)移到文件尾。 清除所有選區(qū)并更新行列狀態(tài)。
顯示補(bǔ)全信息
打開一個(gè)可滾動(dòng)列表以允許選擇現(xiàn)有的名稱。 請(qǐng)參閱下面編輯與導(dǎo)航一節(jié)中的 自動(dòng)補(bǔ)全。
展開文本
展開鍵入的前綴以匹配同一窗口中的完整單詞;重復(fù)以獲得不同的擴(kuò)展。
Show Call Tip
在函數(shù)的右括號(hào)后,打開一個(gè)帶有函數(shù)參數(shù)提示的小窗口。 請(qǐng)參閱下面的“編輯和導(dǎo)航”部分中的 調(diào)用提示。
Show Surrounding Parens
突出顯示周圍的括號(hào)。
格式菜單(僅 window 編輯器)
格式段落
在注釋塊或多行字符串或字符串中的選定行中,重新格式化當(dāng)前以空行分隔的段落。段落中的所有行的格式都將少于N列,其中N默認(rèn)為72。
增加縮進(jìn)
將選定的行右縮進(jìn)(默認(rèn)為4個(gè)空格)。
減少縮進(jìn)
將選定的行左縮進(jìn)(默認(rèn)為4個(gè)空格)。
注釋
在所選行的前面插入 ##。
取消注釋
從所選行中刪除開頭的 # 或 ##。
制表符化
將 前導(dǎo) 空格變成制表符。 (注意:我們建議使用4個(gè)空格來縮進(jìn)Python代碼。)
取消制表符化
將 所有 制表符轉(zhuǎn)換為正確的空格數(shù)。
縮進(jìn)方式切換
打開一個(gè)對(duì)話框,以在制表符和空格之間切換。
縮進(jìn)寬度調(diào)整
打開一個(gè)對(duì)話框以更改縮進(jìn)寬度。 Python社區(qū)接受的默認(rèn)值為4個(gè)空格。
Strip Trailing Chitespace
通過將 str.rstrip 應(yīng)用于每行(包括多行字符串中的行),刪除行尾非空白字符之后的尾隨空格和其他空白字符。除Shell窗口外,在文件末尾刪除多余的換行符。
運(yùn)行菜單(僅 window 編輯器)
運(yùn)行模塊
執(zhí)行 檢查模塊 。如果沒有錯(cuò)誤,重新啟動(dòng) shell 以清理環(huán)境,然后執(zhí)行模塊。輸出顯示在 shell 窗口中。請(qǐng)注意,輸出需要使用 “打印” 或 “寫入”。執(zhí)行完成后,Shell 將保留焦點(diǎn)并顯示提示。此時(shí),可以交互地探索執(zhí)行的結(jié)果。這類似于在命令行執(zhí)行帶有 python -i file 的文件。
運(yùn)行… 定制
與 運(yùn)行模塊 相同,但使用自定義設(shè)置運(yùn)行該模塊。命令行參數(shù) 擴(kuò)展 sys.argv ,就像在命令行上傳遞一樣。該模塊可以在命令行管理程序中運(yùn)行,而無需重新啟動(dòng)。
檢查模塊
檢查 “編輯器” 窗口中當(dāng)前打開的模塊的語法。如果尚未保存該模塊,則 IDLE會(huì)提示用戶保存或自動(dòng)保存,如在 “空閑設(shè)置” 對(duì)話框的 “常規(guī)” 選項(xiàng)卡中所選擇的那樣。如果存在語法錯(cuò)誤,則會(huì)在 “編輯器” 窗口中指示大概位置。
Python Shell
打開或喚醒Python Shell窗口。
Shell 菜單(僅限 Shell 窗口)
查看最近重啟
將Shell窗口滾動(dòng)到上一次Shell重啟。
重啟Shell
重啟 shell 以清理環(huán)境,重置顯示和異常處理。
上一條歷史記錄
循環(huán)瀏覽歷史記錄中與當(dāng)前條目匹配的早期命令。
下一條歷史記錄
循環(huán)瀏覽歷史記錄中與當(dāng)前條目匹配的后續(xù)命令。
中斷執(zhí)行
停止正在運(yùn)行的程序。
調(diào)試菜單(僅限 Shell 窗口)
跳轉(zhuǎn)到文件/行
查看當(dāng)前行。 以光標(biāo)提示,且上一行為文件名和行號(hào)。 如果找到目標(biāo),如果文件尚未打開則打開該文件,并顯示目標(biāo)行。 使用此菜單項(xiàng)來查看異常回溯中引用的源代碼行以及用文件中查找功能找到的行。 也可在 Shell 窗口和 Output 窗口的上下文菜單中使用。
調(diào)試器(切換)
激活后,在Shell中輸入的代碼或從編輯器中運(yùn)行的代碼將在調(diào)試器下運(yùn)行。在編輯器中,可以使用上下文菜單設(shè)置斷點(diǎn)。此功能不完整,具有實(shí)驗(yàn)性。
堆棧查看器
在樹狀目錄中顯示最后一個(gè)異常的堆棧回溯,可以訪問本地和全局。
自動(dòng)打開堆棧查看器
在未處理的異常上切換自動(dòng)打開堆棧查看器。
選項(xiàng)菜單(命令行和編輯器)
配置 IDLE
打開配置對(duì)話框并更改以下各項(xiàng)的首選項(xiàng):字體、縮進(jìn)、鍵綁定、文本顏色主題、啟動(dòng)窗口和大小、其他幫助源和擴(kuò)展名。在MacOS上,通過在應(yīng)用程序菜單中選擇首選項(xiàng)來打開配置對(duì)話框。有關(guān)詳細(xì)信息,請(qǐng)參閱:幫助和首選項(xiàng)下的 首選項(xiàng)設(shè)置。
大多數(shù)配置選項(xiàng)適用于所有窗口或?qū)淼乃写翱凇R韵逻x項(xiàng)僅適用于活動(dòng)窗口。
顯示/隱藏代碼上下文(僅限編輯器窗口)
在編輯窗口頂部打開一個(gè)面板來顯示在窗口頂部滾動(dòng)的代碼塊上下文。 請(qǐng)參閱下文“編輯與導(dǎo)航”章節(jié)中的 代碼上下文。
顯示/隱藏行號(hào)(僅限 Editor 窗口)
在編輯窗口左側(cè)打開一個(gè)顯示代碼文本行編號(hào)的列。 默認(rèn)為關(guān)閉顯示,這可以在首選項(xiàng)中修改 (參見 設(shè)置首選項(xiàng))。
縮放/還原高度
在窗口的正常尺寸和最大高度之間進(jìn)行切換。 初始尺寸默認(rèn)為 40 行每行 80 字符,除非在配置 IDLE 對(duì)話框的通用選項(xiàng)卡中做了修改。 屏幕的最大高度由首次在屏幕上將縮小的窗口最大化的操作來確定。 改變屏幕設(shè)置可能使保存的高度失效。 此切換操作在窗口最大化狀態(tài)下無效。
Window 菜單(命令行和編輯器)
列出所有打開的窗口的名稱;選擇一個(gè)將其帶到前臺(tái)(必要時(shí)對(duì)其進(jìn)行去符號(hào)化)。
幫助菜單(命令行和編輯器)
關(guān)于 IDLE
顯示版本,版權(quán),許可證,榮譽(yù)等。
IDLE 幫助
顯示此 IDLE 文檔,詳細(xì)介紹菜單選項(xiàng),基本編輯和導(dǎo)航以及其他技巧。
Python 文檔
訪問本地Python文檔(如果已安裝),或啟動(dòng)Web瀏覽器并打開docs.python.org顯示最新的Python文檔。
海龜演示
使用示例 Python 代碼運(yùn)行 turtledemo 模塊和海龜繪圖
可以在 “常規(guī)” 選項(xiàng)卡下的 “配置IDLE” 對(duì)話框中添加其他幫助源。有關(guān)“幫助”菜單選項(xiàng)的更多信息,請(qǐng)參見下面的 幫助源 小節(jié)。
Context menus
通過在窗口中右擊(在 macOS 上則為按住 Control 鍵點(diǎn)擊)來打開一個(gè)上下文菜單。 上下文菜單也具有編輯菜單中的標(biāo)準(zhǔn)剪貼板功能。
剪切
復(fù)制選區(qū)至系統(tǒng)剪貼板,然后刪除選區(qū)。
復(fù)制
復(fù)制選區(qū)至系統(tǒng)剪貼板。
粘貼
插入系統(tǒng)剪貼板的內(nèi)容至當(dāng)前窗口。
編輯器窗口也具有斷點(diǎn)功能。 設(shè)置了斷點(diǎn)的行會(huì)被特別標(biāo)記。 斷點(diǎn)僅在啟用調(diào)試器運(yùn)行時(shí)有效。 文件的斷點(diǎn)會(huì)被保存在用戶的 .idlerc 目錄中。
設(shè)置斷點(diǎn)
在當(dāng)前行設(shè)置斷點(diǎn)
清除斷點(diǎn)
清除當(dāng)前行斷點(diǎn)
shell 和輸出窗口還具有以下內(nèi)容。
跳轉(zhuǎn)到文件/行
與調(diào)試菜單相同。
Shell 窗口也有一個(gè)輸出折疊功能,參見下文的 Python Shell 窗口 小節(jié)。
壓縮
如果將光標(biāo)位于輸出行上,則會(huì)折疊在上方代碼和下方提示直到 ‘Squeezed text’ 標(biāo)簽之間的所有輸出。
Editing and Navigation
編輯窗口
IDLE 可以在啟動(dòng)時(shí)打開編輯器窗口,這取決于選項(xiàng)設(shè)置和你啟動(dòng) IDLE 的方式。 在此之后,請(qǐng)使用 File 菜單。 對(duì)于給定的文件只能打開一個(gè)編輯器窗口。
標(biāo)題欄包含文件名稱、完整路徑,以及運(yùn)行該窗口的 Python 和 IDLE 版本。 狀態(tài)欄包含行號(hào) (‘Ln’) 和列號(hào) (‘Col’)。 行號(hào)從 1 開始;列號(hào)則從 0 開始。
IDE 會(huì)定擴(kuò)展名為 .py* 的文件包含 Python 代碼而其他文件不包含。 可使用 Run 菜單來運(yùn)行 Python 代碼。
按鍵綁定
在本節(jié)中,’C’ 是指 Windows 和 Unix 上的 Control 鍵,以及 macOS 上的 Command 鍵。
-
Backspace 向左刪除; Del 向右刪除
-
C-Backspace 向左刪除單詞; C-Del 向右刪除單詞
-
方向鍵和 Page Up/Page Down 移動(dòng)
-
C-LeftArrow 和 C-RightArrow 按單詞移動(dòng)
-
Home/End 跳轉(zhuǎn)到行首/尾
-
C-Home/C-End 跳轉(zhuǎn)到文檔首/尾
-
一些有用的Emacs綁定是從Tcl / Tk繼承的:
-
C-a 行首
-
C-e 行尾
-
C-k 刪除行(但未將其放入剪貼板)
-
C-l 將插入點(diǎn)設(shè)為窗口中心
-
C-b 后退一個(gè)字符而不刪除該字符(通常你也可以用方向鍵進(jìn)行此操作)
-
C-f 前進(jìn)一個(gè)字符而不刪除該字符(通常你也可以用方向鍵進(jìn)行此操作)
-
C-p 向上一行(通常你也可以用方向鍵進(jìn)行此操作)
-
C-d 刪除下一個(gè)字符
-
標(biāo)準(zhǔn)的鍵綁定(例如 C-c 復(fù)制和 C-v 粘貼)仍會(huì)有效。 鍵綁定可在配置 IDLE 對(duì)話框中選擇。
自動(dòng)縮進(jìn)
在一個(gè)代碼塊開頭的語句之后,下一行會(huì)縮進(jìn) 4 個(gè)空格符(在 Python Shell 窗口中是一個(gè)制表符)。 在特定關(guān)鍵字之后(break, return 等),下一行將不再縮進(jìn)。 在開頭的縮進(jìn)中,按 Backspace 將會(huì)刪除 4 個(gè)空格符。 Tab 則會(huì)插入空格符(在 Python Shell 窗口中是一個(gè)制表符),具體數(shù)量取決于縮進(jìn)寬度。 目前,Tab 鍵按照 Tcl/Tk 的規(guī)定設(shè)置為四個(gè)空格符。
另請(qǐng)參閱 Format 菜單 的縮進(jìn)/取消縮進(jìn)區(qū)的命令。
搜索和替換
Any selection becomes a search target. However, only selections within a line work because searches are only performed within lines with the terminal newline removed. If [x] Regular expresion is checked, the target is interpreted according to the Python re module.
補(bǔ)全
當(dāng)被請(qǐng)求并且可用時(shí),將為模塊名、類屬性、函數(shù)或文件名提供補(bǔ)全。 每次請(qǐng)求方法將顯示包含現(xiàn)有名稱的補(bǔ)全提示框。 (例外情況參見下文的 Tab 補(bǔ)全。) 對(duì)于任意提示框,要改變被補(bǔ)全的名稱和提示框中被高亮的條目,可以通過輸入和刪除字符、按 Up, Down, PageUp, PageDown, Home 和 End 鍵;或是在提示框中單擊。 要關(guān)閉補(bǔ)全提示框可以通過 Escape, Enter 或按兩次 Tab 鍵或是在提示框外單擊。 在提示框內(nèi)雙擊則將執(zhí)行選擇并關(guān)閉。
有一種打開提示框的方式是輸入一個(gè)關(guān)鍵字符并等待預(yù)設(shè)的一段間隔。 此間隔默認(rèn)為 2 秒;這可以在設(shè)置對(duì)話框中定制。 (要防止自動(dòng)彈出,可將時(shí)延設(shè)為一個(gè)很大的豪秒數(shù)值,例如 100000000。) 對(duì)于導(dǎo)入的模塊名或者類和函數(shù)屬性,請(qǐng)輸入 ‘.’。 對(duì)于根目錄下的文件名,請(qǐng)?jiān)陂_頭引號(hào)之后立即輸入 os.sep 或 os.altsep。 (在 Windows 下,可以先指定一個(gè)驅(qū)動(dòng)器。) 可通過輸入目錄名和分隔符來進(jìn)入子目錄。
除了等待,或是在提示框關(guān)閉之后,可以使用 Edit 菜單的 Show Completions 來立即打開一個(gè)補(bǔ)全提示框。 默認(rèn)的熱鍵是 C-space。 如果在打開提示框之前輸入一某個(gè)名稱的前綴,則將顯示第一個(gè)匹配項(xiàng)或最接近的項(xiàng)。 結(jié)果將與在提示框已顯示之后輸入前綴時(shí)相同。 在一個(gè)引號(hào)之后執(zhí)行 Show Completions 將會(huì)實(shí)例當(dāng)前目錄下的文件名而不是根目錄下的。
在輸入前綴后按 Tab 鍵的效果通常與 Show Completions 相同。 (如果未輸入前綴則為縮進(jìn)。) 但是,如果輸入的前綴只有一個(gè)匹配項(xiàng),則該匹配項(xiàng)會(huì)立即被添加到編輯器文本中而不打開補(bǔ)全提示框。
在字符串以外且開頭不帶 ‘.’ 地輸入前綴并執(zhí)行 ‘Show Completions’ 或按 Tab 鍵將打開一個(gè)包含關(guān)鍵字、內(nèi)置名稱和現(xiàn)有模塊級(jí)名稱的補(bǔ)全提示框。
當(dāng)在編輯器(而非 Shell)中編輯代碼時(shí),可以通過運(yùn)行你的代碼并在此后不重啟 Shell 來增加可用的模塊級(jí)名稱。 這在文件頂部添加了導(dǎo)入語句之后會(huì)特別有用。 這還會(huì)增加可用的屬性補(bǔ)全。
補(bǔ)全提示框在初始時(shí)會(huì)排除以 ‘_‘ 打頭的名稱,對(duì)于模塊還會(huì)排除未包括在 ‘__all__‘ 中的名稱。 這些隱藏名稱可通過在 ‘.’ 之后輸入 ‘_‘ 來訪問,這在提示框打開之前或之后都是有效的。
提示
當(dāng)在一個(gè) 可用的 函數(shù)名稱之后輸入 ( 時(shí)將自動(dòng)顯示一個(gè)調(diào)用提示。 函數(shù)名稱表達(dá)式可以包括點(diǎn)號(hào)和方括號(hào)索引操作。 調(diào)用提示將保持打開直到它被點(diǎn)擊、光標(biāo)移出參數(shù)區(qū)、或是輸入了 )。 當(dāng)光標(biāo)位于某個(gè)定義的參數(shù)區(qū)時(shí),可以在菜單中選擇 Edit 的 “Show Call Tip” 或是輸入其快捷鍵來顯示調(diào)用提示。
調(diào)用提示是由函數(shù)的簽名和文檔字符串到第一個(gè)空行或第五個(gè)非空行為止的內(nèi)容組成的。 (某些內(nèi)置函數(shù)沒有可訪問的簽名。) 簽名中的 ‘/‘ 或 ‘*‘ 指明其前面或后面的參數(shù)僅限以位置或名稱(關(guān)鍵字)方式傳入。 具體細(xì)節(jié)可能會(huì)改變。
在 Shell 中,可訪問的函數(shù)取決于有哪些模塊已被導(dǎo)入用戶進(jìn)程,包括由 IDLE 本身導(dǎo)入的模塊,以及哪些定義已被運(yùn)行,以上均從最近的重啟動(dòng)開始算起。
例如,重啟動(dòng) Shell 并輸入 itertools.count(。 將顯示調(diào)用提示,因?yàn)?IDLE 出于自身需要已將 itertools 導(dǎo)入了用戶進(jìn)程。 (此行為可能會(huì)改變。) 輸入 turtle.write( 則不顯示任何提示。 因?yàn)?IDLE 本身不會(huì)導(dǎo)入 turtle。 菜單項(xiàng)和快捷鍵同樣不會(huì)有任何反應(yīng)。 輸入 import turtle。 則在此之后,turtle.write( 將顯示調(diào)用提示。
在編輯器中,import 語句在文件運(yùn)行之前是沒有效果的。 在輸入 import 語句之后、添加函數(shù)定義之后,或是打開一個(gè)現(xiàn)有文件之后可以先運(yùn)行一下文件。
代碼上下文
在一個(gè)包含 Python 代碼的編輯器窗口內(nèi)部,可以切換代碼上下文以便顯示或隱藏窗口頂部的面板。 當(dāng)顯示時(shí),此面板可以凍結(jié)代碼塊的開頭行,例如以 class, def 或 if 關(guān)鍵字開頭的行,這樣的行在不顯示時(shí)面板時(shí)可能離開視野。 此面板的大小將根據(jù)需要擴(kuò)展和收縮以顯示當(dāng)前層級(jí)的全部上下文,直至達(dá)到配置 IDLE 對(duì)話框中所定義的最大行數(shù)(默認(rèn)為 15)。 如果如果沒有當(dāng)前上下文行而此功能被啟用,則將顯示一個(gè)空行。 點(diǎn)擊上下文面板中的某一行將把該行移至編輯器頂部。
上下文面板的文本和背景顏色可在配置 IDLE 對(duì)話框的 Highlights 選項(xiàng)卡中進(jìn)行配置。
Shell window
In IDLE’s Shell, enter, edit, and recall complete statements. (Most consoles and terminals only work with a single physical line at a time).
Submit a single-line statement for execution by hitting Return with the cursor anywhere on the line. If a line is extended with Backslash (\), the cursor must be on the last physical line. Submit a multi-line compound statement by entering a blank line after the statement.
When one pastes code into Shell, it is not compiled and possibly executed until one hits Return, as specified above. One may edit pasted code first. If one pastes more than one statement into Shell, the result will be a SyntaxError when multiple statements are compiled as if they were one.
Lines containing RESTART mean that the user execution process has been re-started. This occurs when the user execution process has crashed, when one requests a restart on the Shell menu, or when one runs code in an editor window.
之前小節(jié)中描述的編輯功能在交互式地輸入代碼時(shí)也可使用。 IDLE 的 Shell 窗口還會(huì)響應(yīng)以下按鍵。
-
C-c 中斷執(zhí)行命令
-
C-d 發(fā)送文件結(jié)束命令;如果在
>>>提示符后按下會(huì)關(guān)閉窗口。 -
Alt-/ (擴(kuò)展單詞) 也有助于減少按鍵量
歷史命令
-
Alt-p 提取與你所輸入鍵匹配的前一條命令。 在 macOS 上請(qǐng)使用 C-p。
-
Alt-n 提取下一條命令。 在 macOS 上請(qǐng)使用 C-n。
-
Return while the cursor is on any previous command retrieves that command
-
文本顏色
IDLE 文本默認(rèn)為白底黑字,但有特殊含義的文本將以彩色顯示。 對(duì)于 Shell 來說包括 Shell 輸出,Shell 錯(cuò)誤,用戶輸出和用戶錯(cuò)誤。 對(duì)于 Shell 提示符下或編輯器中的 Python 代碼來說則包括關(guān)鍵字,內(nèi)置類和函數(shù)名稱,class 和 def 之后的名稱,字符串和注釋等。 對(duì)于任意文本窗口來說則包括光標(biāo)(如果存在)、找到的文本(如果可能)和選定的文本。
IDLE 還會(huì)高亮顯示模式匹配語句中的 軟關(guān)鍵字 match, case 和 _。 但是,這種高亮顯示并不完美,在某些極端情況下還會(huì)出現(xiàn)錯(cuò)誤,包括 _ 在 case 模式中出現(xiàn)的時(shí)候。
廣西著色是在背景上完成的,因此有時(shí)會(huì)看到非著色的文本。 要改變顏色方案,請(qǐng)使用配置 IDLE 對(duì)話框的高亮選項(xiàng)卡。 編輯器中的調(diào)試器斷點(diǎn)行標(biāo)記和彈出面板和對(duì)話框中的文本則是用戶不可配置的。
Startup and Code Execution
在附帶 -s 選項(xiàng)啟用的情況下,IDLE 將會(huì)執(zhí)行環(huán)境變量 IDLESTARTUP 或 PYTHONSTARTUP 所引用的文件。 IDLE 會(huì)先檢查 IDLESTARTUP;如果 IDLESTARTUP 存在則會(huì)運(yùn)行被引用的文件。 如果 IDLESTARTUP 不存在,則 IDLE 會(huì)檢查 PYTHONSTARTUP。 這些環(huán)境變量所引用的文件是存放經(jīng)常被 IDLE Shell 所使用的函數(shù),或者執(zhí)行導(dǎo)入常用模塊的 import 語句的便捷場(chǎng)所。
此外,Tk 也會(huì)在存在啟動(dòng)文件時(shí)加載它。 請(qǐng)注意 Tk 文件會(huì)被無條件地加載。 此附加文件名為 .Idle.py 并且會(huì)在用戶的家目錄下查找。 此文件中的語句將在 Tk 的命名空間中執(zhí)行,所以此文件不適用于導(dǎo)入要在 IDLE 的 Python Shell 中使用的函數(shù)。
命令行用法
idle.py [-c command] [-d] [-e] [-h] [-i] [-r file] [-s] [-t title] [-] [arg] ...-c command run command in the shell window-d enable debugger and open shell window-e open editor window-h print help message with legal combinations and exit-i open shell window-r file run file in shell window-s run $IDLESTARTUP or $PYTHONSTARTUP first, in shell window-t title set title of shell window- run stdin in shell (- must be last option before args)
如果有參數(shù):
-
如果使用了
-,-c或r,則放在sys.argv[1:...]和sys.argv[0]中的所有參數(shù)都會(huì)被設(shè)為'','-c'或'-r'。 不會(huì)打開任何編輯器窗口,即使是在選項(xiàng)對(duì)話框中的默認(rèn)設(shè)置。 -
在其他情況下,參數(shù)為要打開編輯的文件而
sys.argv反映的是傳給 IDLE 本身的參數(shù)。
啟動(dòng)失敗
IDLE 使用一個(gè)套接字在 IDLE GUI 進(jìn)程和用戶代碼執(zhí)行進(jìn)程之間通信。 當(dāng) Shell 啟動(dòng)或重啟動(dòng)時(shí)必須建立一個(gè)連接。 (重啟動(dòng)會(huì)以一個(gè)內(nèi)容為 ‘RESTART’ 的分隔行來標(biāo)示)。 如果用戶進(jìn)程無法連接到 GUI 進(jìn)程,它通常會(huì)顯示一個(gè)包含 ‘cannot connect’ 消息的 Tk 錯(cuò)誤提示框來引導(dǎo)用戶。 隨后將會(huì)退出程序。
有一個(gè) Unix 系統(tǒng)專屬的連接失敗是由系統(tǒng)網(wǎng)絡(luò)設(shè)置中錯(cuò)誤配置的掩碼規(guī)則導(dǎo)致的。 當(dāng)從一個(gè)終端啟動(dòng) IDLE 時(shí),用戶將看到一條以 ** Invalid host: 開頭的消息。 有效的值為 127.0.0.1 (idlelib.rpc.LOCALHOST)。 用戶可以在一個(gè)終端窗口輸入 tcpconnect -irv 127.0.0.1 6543 并在另一個(gè)終端窗口中輸入 tcplisten 來進(jìn)行診斷。
導(dǎo)致連接失敗的一個(gè)常見原因是用戶創(chuàng)建的文件與標(biāo)準(zhǔn)庫(kù)模塊同名,例如 random.py 和 tkinter.py。 當(dāng)這樣的文件與要運(yùn)行的文件位于同一目錄中時(shí),IDLE 將無法導(dǎo)入標(biāo)準(zhǔn)庫(kù)模塊。 可用的解決辦法是重命名用戶文件。
雖然現(xiàn)在已不太常見,但殺毒軟件或防火墻程序也有可能會(huì)阻止連接。 如果無法將此類程序設(shè)為允許連接,那么為了運(yùn)行 IDLE 就必須將其關(guān)閉。 允許這樣的內(nèi)部連接是安全的,因?yàn)閿?shù)據(jù)在外部端口上不可見。 一個(gè)類似的問題是錯(cuò)誤的網(wǎng)絡(luò)配置阻止了連接。
Python 的安裝問題有時(shí)會(huì)使 IDLE 退出:存在多個(gè)版本時(shí)可能導(dǎo)致程序崩潰,或者單獨(dú)安裝時(shí)可能需要管理員權(quán)限。 如果想要避免程序崩潰,或是不想以管理員身份運(yùn)行,最簡(jiǎn)單的做法是完全卸載 Python 并重新安裝。
有時(shí)會(huì)出現(xiàn) pythonw.exe 僵尸進(jìn)程問題。 在 Windows 上,可以使用任務(wù)管理員來檢查并停止該進(jìn)程。 有時(shí)由程序崩潰或鍵盤中斷(control-C)所發(fā)起的重啟動(dòng)可能會(huì)出現(xiàn)連接失敗。 關(guān)閉錯(cuò)誤提示框或使用 Shell 菜單中的 Restart Shell 可能會(huì)修復(fù)此類臨時(shí)性錯(cuò)誤。
當(dāng) IDLE 首次啟動(dòng)時(shí),它會(huì)嘗試讀取 ~/.idlerc/ 中的用戶配置文件(~ 是用戶的家目錄)。 如果配置有問題,則應(yīng)當(dāng)顯示一條錯(cuò)誤消息。 除隨機(jī)磁盤錯(cuò)誤之外,此類錯(cuò)誤均可通過不手動(dòng)編輯這些文件來避免。 請(qǐng)使用 Options 菜單來打開配置對(duì)話框。 一旦用戶配置文件出現(xiàn)錯(cuò)誤,最好的解決辦法就是刪除它并使用配置對(duì)話框重新設(shè)置。
如果 IDLE 退出時(shí)沒有發(fā)出任何錯(cuò)誤消息,并且它不是通過控制臺(tái)啟動(dòng)的,請(qǐng)嘗試通過控制臺(tái)或終端 (python -m idlelib) 來啟動(dòng)它以查看是否會(huì)出現(xiàn)錯(cuò)誤消息。
在基于 Unix 的系統(tǒng)上使用 tcl/tk 低于 8.6.11 的版本 (查看 About IDLE) 時(shí)特定字體的特定字符可能導(dǎo)致終端提示 tk 錯(cuò)誤消息。 這可能發(fā)生在啟動(dòng) IDLE 編輯包此種字符的文件或是在之后輸入此種字符的時(shí)候。 如果無法升級(jí) tcl/tk,可以重新配置 IDLE 來使用其他的字體。
運(yùn)行用戶代碼
除了少量例外,使用 IDLE 執(zhí)行 Python 代碼的結(jié)果應(yīng)當(dāng)與使用默認(rèn)方法,即在文本模式的系統(tǒng)控制臺(tái)或終端窗口中直接通過 Python 解釋器執(zhí)行同樣的代碼相同。 但是,不同的界面和操作有時(shí)會(huì)影響顯示的結(jié)果。 例如,sys.modules 初始時(shí)具有更多條目,而 threading.active_count() 將返回 2 而不是 1。
在默認(rèn)情況下,IDLE 會(huì)在單獨(dú)的 OS 進(jìn)程中運(yùn)行用戶代碼而不是在運(yùn)行 Shell 和編輯器的用戶界面進(jìn)程中運(yùn)行。 在執(zhí)行進(jìn)程中,它會(huì)將 sys.stdin, sys.stdout 和 sys.stderr 替換為從 Shell 窗口獲取輸入并向其發(fā)送輸出的對(duì)象。 保存在 sys.__stdin__, sys.__stdout__ 和 sys.__stderr__ 中的原始值不會(huì)被改變,但可能會(huì)為 None。
將打印輸出從一個(gè)進(jìn)程發(fā)送到另一個(gè)進(jìn)程中的文本部件要比打印到同一個(gè)進(jìn)程中的系統(tǒng)終端慢。 這在打印多個(gè)參數(shù)時(shí)將有更明顯的影響,因?yàn)槊總€(gè)參數(shù)、每個(gè)分隔符和換行符對(duì)應(yīng)的字符串都要單獨(dú)發(fā)送。 在開發(fā)中,這通常不算是問題,但如果希望能在 IDLE 中更快地打印,可以將想要顯示的所有內(nèi)容先格式化并拼接到一起然后打印單個(gè)字符串。 格式字符串和 str.join() 都可以被用于合并字段和文本行。
IDLE’s standard stream replacements are not inherited by subprocesses created in the execution process, whether directly by user code or by modules such as multiprocessing. If such subprocess use input from sys.stdin or print or write to sys.stdout or sys.stderr, IDLE should be started in a command line window. (On Windows, use python or py rather than pythonw or pyw.) The secondary subprocess will then be attached to that window for input and output.
如果 sys 被用戶代碼重置,例如使用了 importlib.reload(sys),則 IDLE 的修改將丟失,來自鍵盤的輸入和向屏幕的輸出將無法正確運(yùn)作。
當(dāng) Shell 獲得焦點(diǎn)時(shí),它將控制鍵盤與屏幕。 這通常會(huì)保持透明,但一些直接訪問鍵盤和屏幕的函數(shù)將會(huì)不起作用。 這也包括那些確定是否有鍵被按下以及是哪個(gè)鍵被按下的系統(tǒng)專屬函數(shù)。
在執(zhí)行進(jìn)程中運(yùn)行的 IDLE 代碼會(huì)向調(diào)用棧添加在其他情況下不存在的幀。 IDLE 包裝了 sys.getrecursionlimit 和 sys.setrecursionlimit 以減少額外棧幀的影響。
當(dāng)用戶代碼直接或者通過調(diào)用 sys.exit 引發(fā) SystemExit 時(shí),IDLE 將返回 Shell 提示符而非完全退出。
Shell中的用戶輸出
當(dāng)一個(gè)程序輸出文本時(shí),結(jié)果將由相應(yīng)的輸出設(shè)備來確定。 當(dāng) IDLE 執(zhí)行用戶代碼時(shí),sys.stdout 和 sys.stderr 會(huì)被連接到 IDLE Shell 的顯示區(qū)。 它的某些特性是從底層的 Tk Text 部件繼承而來。 其他特性則是程序所添加的。 總之,Shell 被設(shè)計(jì)用于開發(fā)環(huán)境而非生產(chǎn)環(huán)境運(yùn)行。
例如,Shell 絕不會(huì)丟棄輸出。 一個(gè)向 Shell 發(fā)送無限輸出的程序?qū)⒆罱K占滿內(nèi)存,導(dǎo)致內(nèi)存錯(cuò)誤。 作為對(duì)比,某些系統(tǒng)文本模式窗口只會(huì)保留輸出的最后 n 行。 例如,Windows 控制臺(tái)可由用戶設(shè)置保留 1 至 9999 行,默認(rèn)為 300 行。
A Tk Text widget, and hence IDLE’s Shell, displays characters (codepoints) in the BMP (Basic Multilingual Plane) subset of Unicode. Which characters are displayed with a proper glyph and which with a replacement box depends on the operating system and installed fonts. Tab characters cause the following text to begin after the next tab stop. (They occur every 8 ‘characters’). Newline characters cause following text to appear on a new line. Other control characters are ignored or displayed as a space, box, or something else, depending on the operating system and font. (Moving the text cursor through such output with arrow keys may exhibit some surprising spacing behavior.)
>>> s = 'a\tb\a<\x02><\r>\bc\nd' # Enter 22 chars.>>> len(s)14>>> s # Display repr(s)'a\tb\x07<\x02><\r>\x08c\nd'>>> print(s, end='') # Display s as is.# Result varies by OS and font. Try it.
repr 函數(shù)會(huì)被用于表達(dá)式值的交互式回顯。 它將返回輸入字符串的一個(gè)修改版本,其中的控制代碼、部分 BMP 碼位以及所有非 BMP 碼位都將被替換為轉(zhuǎn)義代碼。 如上面所演示的,它使用戶可以辨識(shí)字符串中的字符,無論它們會(huì)如何顯示。
普通的與錯(cuò)誤的輸出通常會(huì)在與代碼輸入和彼此之間保持區(qū)分 (顯示于不同的行)。 它們也會(huì)分別使用不同的高亮顏色。
對(duì)于 SyntaxError 回溯信息,表示檢測(cè)到錯(cuò)誤位置的正常 ‘^’ 標(biāo)記被替換為帶有代表錯(cuò)誤的文本顏色高亮。 當(dāng)從文件運(yùn)行的代碼導(dǎo)致了其他異常時(shí),用戶可以右擊回溯信息行在 IDLE 編輯器中跳轉(zhuǎn)到相應(yīng)的行。 如有必要將打開相應(yīng)的文件。
Shell 具有將輸出行折疊為一個(gè) ‘Squeezed text’ 標(biāo)簽的特殊功能。 此功能將自動(dòng)應(yīng)用于超過 N 行的輸出 (默認(rèn) N = 50)。 N 可以在設(shè)置對(duì)話框中 General 頁的 PyShell 區(qū)域中修改。 行數(shù)更少的輸出也可通過在輸出上右擊來折疊。 此功能適用于過多的輸出行數(shù)導(dǎo)致滾動(dòng)操作變慢的情況。
已折疊的輸出可通過雙擊該標(biāo)簽來原地展開。 也可通過右擊該標(biāo)簽將其發(fā)送到剪貼板或單獨(dú)的查看窗口。
開發(fā) tkinter 應(yīng)用程序
IDLE 有意與標(biāo)準(zhǔn) Python 保持區(qū)別以方便 tkinter 程序的開發(fā)。 在標(biāo)準(zhǔn) Python 中輸入 import tkinter as tk; root = tk.Tk() 不會(huì)顯示任何東西。 在 IDLE 中輸入同樣的代碼則會(huì)顯示一個(gè) tk 窗口。 在標(biāo)準(zhǔn) Python 中,還必須輸入 root.update() 才會(huì)將窗口顯示出來。 IDLE 會(huì)在幕后執(zhí)行同樣的方法,每秒大約 20 次,即每隔大約 50 毫秒。 下面輸入 b = tk.Button(root, text='button'); b.pack()。 在標(biāo)準(zhǔn) Python 中仍然不會(huì)有任何可見的變化,直到輸入 root.update()。
大多數(shù) tkinter 程序都會(huì)運(yùn)行 root.mainloop(),它通常直到 tk 應(yīng)用被銷毀時(shí)才會(huì)返回。 如果程序是通過 python -i 或 IDLE 編輯器運(yùn)行的,則 >>> Shell 提示符將直到 mainloop() 返回時(shí)才會(huì)出現(xiàn),這時(shí)將結(jié)束程序的交互。
當(dāng)通過 IDLE 編輯器運(yùn)行 tkinter 程序時(shí),可以注釋掉 mainloop 調(diào)用。 這樣將立即回到 Shell 提示符并可與正在運(yùn)行的應(yīng)用程序交互。 請(qǐng)記得當(dāng)在標(biāo)準(zhǔn) Python 中運(yùn)行時(shí)重新啟用 mainloop 調(diào)用。
在沒有子進(jìn)程的情況下運(yùn)行
在默認(rèn)情況下,IDLE 是通過一個(gè)套接字在單獨(dú)的子進(jìn)程中執(zhí)行用戶代碼,它將使用內(nèi)部的環(huán)回接口。 這個(gè)連接在外部不可見并且不會(huì)在互聯(lián)網(wǎng)上發(fā)送或接收數(shù)據(jù)。 如果防火墻仍然會(huì)報(bào)警,你完全可以忽略。
如果創(chuàng)建套接字連接的嘗試失敗,IDLE 將會(huì)通知你。 這樣的失敗可能是暫時(shí)性的,但是如果持續(xù)存在,問題可能是防火墻阻止了連接或某個(gè)系統(tǒng)配置錯(cuò)誤。 在問題得到解決之前,可以使用 -n 命令行開關(guān)來運(yùn)行 IDLE。
如果 IDLE 啟動(dòng)時(shí)使用了 -n 命令行開關(guān)則它將在單個(gè)進(jìn)程中運(yùn)行并且將不再創(chuàng)建運(yùn)行 RPC Python 執(zhí)行服務(wù)器的子進(jìn)程。 這適用于 Python 無法在你的系統(tǒng)平臺(tái)上創(chuàng)建子進(jìn)程或 RPC 套接字接口的情況。 但是,在這種模式下用戶代碼沒有與 IDLE 本身相隔離。 而且,當(dāng)選擇 Run/Run Module (F5) 時(shí)運(yùn)行環(huán)境也不會(huì)重啟。 如果你的代碼已被修改,你必須為受影響的模塊執(zhí)行 reload() 并重新導(dǎo)入特定的條目 (例如 from foo import baz) 才能讓修改生效。 出于這些原因,在可能的情況下最好還是使用默認(rèn)的子進(jìn)程來運(yùn)行 IDLE。
3.4 版后已移除.
Help and Preferences
幫助源
Help 菜單項(xiàng) “IDLE Help” 會(huì)顯示標(biāo)準(zhǔn)庫(kù)參考中 IDLE 一章的帶格式 HTML 版本。 這些內(nèi)容放在只讀的 tkinter 文本窗口中,與在瀏覽器中看到的內(nèi)容類似。 可使用鼠標(biāo)滾輪、滾動(dòng)條或上下方向鍵來瀏覽文本。 或是點(diǎn)擊 TOC (Table of Contents) 按鈕并在打開的選項(xiàng)框中選擇一個(gè)節(jié)標(biāo)題。
Help 菜單項(xiàng) “Python Docs” 會(huì)打開更豐富的幫助源,包括教程,通過 docs.python.org/x.y 來訪問,其中 ‘x.y’ 是當(dāng)前運(yùn)行的 Python 版本。 如果你的系統(tǒng)有此文檔的離線副本 (這可能是一個(gè)安裝選項(xiàng)),則將打開這個(gè)副本。
選定的 URL 可以使用配置 IDLE 對(duì)話框的 General 選項(xiàng)卡隨時(shí)在幫助菜單中添加或移除。
首選項(xiàng)設(shè)置
字體首選項(xiàng)、高亮、按鍵和通用首選項(xiàng)可通過 Option 菜單的配置 IDLE 項(xiàng)來修改。 非默認(rèn)的用戶設(shè)置將保存在用戶家目錄下的 .idlerc 目錄中。 用戶配置文件錯(cuò)誤導(dǎo)致的問題可通過編輯或刪除 .idlerc 中的一個(gè)或多個(gè)文件來解決。
在 Font 選項(xiàng)卡中,可以查看使用多種語言的多個(gè)字符的示例文本來了解字體或字號(hào)效果。 可以編輯示例文本來添加想要的其他字符。 請(qǐng)使用示例文本選擇等寬字體。 如果某些字符在 Shell 或編輯器中的顯示有問題,可以將它們添加到示例文本的開頭并嘗試改變字號(hào)和字體。
在 Highlights 和 Keys 選項(xiàng)卡中,可以選擇內(nèi)置或自定義的顏色主題和按鍵集合。 要將更新的內(nèi)置顏色主題或按鍵集合與舊版 IDLE 一起使用,可以將其保存為新的自定義主題或按鍵集合就將可在舊版 IDLE 中使用。
macOS 上的IDLE
在 System Preferences: Dock 中,可以將 “Prefer tabs when opening documents” 設(shè)為 “Always”。 但是該設(shè)置不能兼容 IDLE 所使用的 tk/tkinter GUI 框架,并會(huì)使得部分 IDLE 特性失效。
擴(kuò)展
IDLE 可以包含擴(kuò)展插件。 擴(kuò)展插件的首選項(xiàng)可通過首選項(xiàng)對(duì)話框的 Extensions 選項(xiàng)卡來修改。 請(qǐng)查看 idlelib 目錄下 config-extensions.def 的開頭來了解詳情。 目前唯一的擴(kuò)展插件是 zzdummy,它也是一個(gè)測(cè)試用的示例。
idlelib
Source code: Lib/idlelib
The Lib/idlelib package implements the IDLE application. See the rest of this page for how to use IDLE.
The files in idlelib are described in idlelib/README.txt. Access it either in idlelib or click Help => About IDLE on the IDLE menu. This file also maps IDLE menu items to the code that implements the item. Except for files listed under ‘Startup’, the idlelib code is ‘private’ in sense that feature changes can be backported (see PEP 434).
網(wǎng)頁標(biāo)題:創(chuàng)新互聯(lián)Python教程:IDLE
網(wǎng)站地址:http://www.5511xx.com/article/cdcophc.html


咨詢
建站咨詢
