IDLE?
源代碼: Lib/idlelib/
IDLE 是 Python 所內置的開發與學習環境。
IDLE 具有以下特性:
編碼于 100% 純正的 Python,使用名為
tkinter的圖形用戶界面工具跨平臺:在 Windows、Unix 和 macOS 上工作近似。
提供輸入輸出高亮和錯誤信息的 Python 命令行窗口 (交互解釋器)
提供多次撤銷操作、Python 語法高亮、智能縮進、函數調用提示、自動補全等功能的多窗口文本編輯器
在多個窗口中檢索,在編輯器中替換文本,以及在多個文件中檢索(通過 grep)
提供持久保存的斷點調試、單步調試、查看本地和全局命名空間功能的調試器
配置、瀏覽以及其它對話框
目錄?
IDEL 具有兩個主要窗口類型,分別是命令行窗口和編輯器窗口。用戶可以同時打開多個編輯器窗口。對于 Windows 和 Linux 平臺,都有各自的主菜單。如下記錄的每個菜單標識著與之關聯的窗口類型。
導出窗口,例如使用 編輯=>在文件中查找 是編輯器窗口的的一個子類型。它們目前有著相同的主菜單,但是默認標題和上下文菜單不同。
在macOS上,只有一個應用程序菜單。它根據當前選擇的窗口動態變化。它具有一個IDLE菜單,并且下面描述的某些條目已移動到符合Apple準則的位置。
文件目錄 (命令行和編輯器)?
- 新建文件
創建一個文件編輯器窗口。
- 打開...
使用打開窗口以打開一個已存在的文件。
- 近期文件
打開一個近期文件列表,選取一個以打開它。
- 打開模塊...
打開一個已存在的模塊 (搜索 sys.path)
- 類瀏覽器
于當前所編輯的文件中使用樹形結構展示函數、類以及方法。在命令行中,首先打開一個模塊。
- 路徑瀏覽
在樹狀結構中展示 sys.path 目錄、模塊、函數、類和方法。
- 保存
如果文件已經存在,則將當前窗口保存至對應的文件。自打開或上次保存之后經過修改的文件的窗口標題欄首尾將出現星號 * 。如果沒有對應的文件,則使用“另存為”代替。
- 保存為...
使用“保存為”對話框保存當前窗口。被保存的文件將作為當前窗口新的對應文件。
- 另存為副本...
保存當前窗口至另一個文件,而不修改當前對應文件。
- 打印窗口
通過默認打印機打印當前窗口。
- 關閉
關閉當前窗口(如果未保存則詢問)。
- 退出
關閉所有窗口并退出 IDLE(如果未保存則詢問)
編輯目錄(命令行和編輯器)?
- 撤銷操作
撤銷當前窗口的最近一次操作。最高可以撤回 1000 條操作記錄。
- 重做
重做當前窗口最近一次所撤銷的操作。
- 剪切
復制選區至系統剪貼板,然后刪除選區。
- 復制
復制選區至系統剪貼板。
- 粘貼
插入系統剪貼板的內容至當前窗口。
剪貼板功能也可用于上下文目錄。
- 全選
選擇當前窗口的全部內容。
- 查找...
打開一個提供多選項的查找窗口。
- 再次查找
重復上次搜索,如果結果存在。
- 查找選區
查找當前選中的字符串,如果存在
- 在文件中查找...
打開文件查找對話框。將結果輸出至新的輸出窗口。
- 替換...
打開 查找并替換 對話框。
- 前往行
將光標移到所請求行的開頭并使該行可見。 對于超過文件尾的請求將會移到文件尾。 清除所有選區并更新行列狀態。
- 提示完成
打開一個可滾動列表,允許選擇關鍵字和屬性。請參閱下面的 “編輯和導航”部分中的 Completions 。
- 展開文本
展開鍵入的前綴以匹配同一窗口中的完整單詞;重復以獲得不同的擴展。
- 顯示調用貼士
在函數的右括號后,打開一個帶有函數參數提示的小窗口。請參閱下面的“編輯和導航”部分中的 Calltips 。
- 顯示周圍括號
突出顯示周圍的括號。
格式菜單(僅 window 編輯器)?
- 縮進區域
將選定的行右移縮進寬度(默認為4個空格)。
- 區域減少縮進
將選定的行向左移動縮進寬度(默認為4個空格)。
- 區域注釋
在所選行的前面插入 ##。
- 區域取消注釋
從所選行中刪除開頭的 # 或 ##。
- 區域添加制表符
將 前導 空格變成制表符。 (注意:我們建議使用4個空格來縮進Python代碼。)
- 區域取消制表符
將 所有 制表符轉換為正確的空格數。
- 切換標簽
打開一個對話框,以在縮進和空格之間切換。
- 新縮進寬度
打開一個對話框以更改縮進寬度。 Python社區接受的默認值為4個空格。
- 格式段落
在注釋塊或多行字符串或字符串中的選定行中,重新格式化當前以空行分隔的段落。段落中的所有行的格式都將少于N列,其中N默認為72。
- 尾隨空格
通過將 str.rstrip 應用于每行(包括多行字符串中的行),刪除行尾非空白字符之后的尾隨空格和其他空白字符。除Shell窗口外,在文件末尾刪除多余的換行符。
運行菜單(僅 window 編輯器)?
- 運行模塊
執行 檢查模塊 。如果沒有錯誤,重新啟動 shell 以清理環境,然后執行模塊。輸出顯示在 shell 窗口中。請注意,輸出需要使用 “打印” 或 “寫入”。執行完成后,Shell 將保留焦點并顯示提示。此時,可以交互地探索執行的結果。這類似于在命令行執行帶有
python -i file的文件。
- 檢查模塊
檢查 “編輯器” 窗口中當前打開的模塊的語法。如果尚未保存該模塊,則 IDLE會提示用戶保存或自動保存,如在 “空閑設置” 對話框的 “常規” 選項卡中所選擇的那樣。如果存在語法錯誤,則會在 “編輯器” 窗口中指示大概位置。
- Python Shell
打開或喚醒Python Shell窗口。
Shell 菜單(僅 window 編輯器)?
- 查看最近重啟
將Shell窗口滾動到上一次Shell重啟。
- 重啟Shell
重新啟動shell 以清理環境。
- 上一條歷史記錄
循環瀏覽歷史記錄中與當前條目匹配的早期命令。
- 下一條歷史記錄
循環瀏覽歷史記錄中與當前條目匹配的后續命令。
- 中斷執行
停止正在運行的程序。
調試菜單(僅 window 編輯器)?
- 跳轉到文件/行
查看當前行。 以光標提示,且上一行為文件名和行號。 如果找到目標,如果文件尚未打開則打開該文件,并顯示目標行。 使用此菜單項來查看異常回溯中引用的源代碼行以及用文件中查找功能找到的行。 也可在 Shell 窗口和 Output 窗口的上下文菜單中使用。
- 調試器(切換)
激活后,在Shell中輸入的代碼或從編輯器中運行的代碼將在調試器下運行。在編輯器中,可以使用上下文菜單設置斷點。此功能不完整,具有實驗性。
- 堆棧查看器
在樹狀目錄中顯示最后一個異常的堆棧回溯,可以訪問本地和全局。
- 自動打開堆棧查看器
在未處理的異常上切換自動打開堆棧查看器。
選項菜單(命令行和編輯器)?
- 配置 IDLE
打開配置對話框并更改以下各項的首選項:字體、縮進、鍵綁定、文本顏色主題、啟動窗口和大小、其他幫助源和擴展名。在MacOS上,通過在應用程序菜單中選擇首選項來打開配置對話框。有關詳細信息,請參閱:幫助和首選項下的 首選項設置。
大多數配置選項適用于所有窗口或將來的所有窗口。以下選項僅適用于活動窗口。
Window 菜單(命令行和編輯器)?
列出所有打開的窗口的名稱;選擇一個將其帶到前臺(必要時對其進行去符號化)。
幫助菜單(命令行和編輯器)?
- 關于 IDLE
顯示版本,版權,許可證,榮譽等。
- IDLE 幫助
顯示此 IDLE 文檔,詳細介紹菜單選項,基本編輯和導航以及其他技巧。
- Python 文檔
訪問本地Python文檔(如果已安裝),或啟動Web瀏覽器并打開docs.python.org顯示最新的Python文檔。
- 海龜演示
使用示例Python代碼和turtle繪圖運行turtledemo模塊。
可以在“常規”選項卡下的“配置IDLE”對話框中添加其他幫助源。有關“幫助”菜單選項的更多信息,請參見下面的 幫助資源 小節。
上下文菜單?
通過在窗口中右擊(在 macOS 上則為按住 Control 鍵點擊)來打開一個上下文菜單。 上下文菜單也具有編輯菜單中的標準剪貼板功能。
- 剪切
復制選區至系統剪貼板,然后刪除選區。
- 復制
復制選區至系統剪貼板。
- 粘貼
插入系統剪貼板的內容至當前窗口。
編輯器窗口也具有斷點功能。 設置了斷點的行會被特別標記。 斷點僅在啟用調試器運行時有效。 文件的斷點會被保存在用戶的 .idlerc 目錄中。
- 設置斷點
在當前行設置斷點
- 清除斷點
清除當前行斷點
shell 和輸出窗口還具有以下內容。
- 跳轉到文件/行
與調試菜單相同。
Shell 窗口也有一個輸出折疊功能,參見下文的 Python Shell 窗口 小節。
- 壓縮
如果將光標位于輸出行上,則會折疊在上方代碼和下方提示直到 'Squeezed text' 標簽之間的所有輸出。
編輯和導航?
編輯窗口?
IDLE 可以在啟動時打開編輯器窗口,這取決于選項設置和你啟動 IDLE 的方式。 在此之后,請使用 File 菜單。 對于給定的文件只能打開一個編輯器窗口。
標題欄包含文件名稱、完整路徑,以及運行該窗口的 Python 和 IDLE 版本。 狀態欄包含行號 ('Ln') 和列號 ('Col')。 行號從 1 開始;列號則從 0 開始。
IDE 會定擴展名為 .py* 的文件包含 Python 代碼而其他文件不包含。 可使用 Run 菜單來運行 Python 代碼。
按鍵綁定?
在本節中,'C' 是指 Windows 和 Unix 上的 Control 鍵,以及 macOS 上的 Command 鍵。
Backspace 向左刪除; Del 向右刪除
C-Backspace 向左刪除單詞; C-Del 向右刪除單詞
方向鍵和 Page Up/Page Down 移動
C-LeftArrow 和 C-RightArrow 按字移動
Home/End 跳轉到行首/尾
C-Home/C-End 跳轉到文檔首/尾
一些有用的Emacs綁定是從Tcl / Tk繼承的:
C-a 行首
C-e 行尾
C-k 刪除行(但未將其放入剪貼板)
C-l 將插入點設為窗口中心
C-b 后退一個字符而不刪除該字符(通常你也可以用方向鍵進行此操作)
C-f 前進一個字符而不刪除該字符(通常你也可以用方向鍵進行此操作)
C-p 向上一行(通常你也可以用方向鍵進行此操作)
C-d 刪除下一個字符
標準的鍵綁定(例如 C-c 復制和 C-v 粘貼)仍會有效。 鍵綁定可在配置 IDLE 對話框中選擇。
自動縮進?
在一個代碼塊開頭的語句之后,下一行會縮進 4 個空格符(在 Python Shell 窗口中是一個制表符)。 在特定關鍵字之后(break, return 等),下一行將不再縮進。 在開頭的縮進中,按 Backspace 將會刪除 4 個空格符。 Tab 則會插入空格符(在 Python Shell 窗口中是一個制表符),具體數量取決于縮進寬度。 目前,Tab 鍵按照 Tcl/Tk 的規定設置為四個空格符。
另請參閱 Format 菜單 的縮進/取消縮進區的命令。
完成?
Completions are supplied for functions, classes, and attributes of classes, both built-in and user-defined. Completions are also provided for filenames.
The AutoCompleteWindow (ACW) will open after a predefined delay (default is two seconds) after a '.' or (in a string) an os.sep is typed. If after one of those characters (plus zero or more other characters) a tab is typed the ACW will open immediately if a possible continuation is found.
If there is only one possible completion for the characters entered, a Tab will supply that completion without opening the ACW.
'Show Completions' will force open a completions window, by default the C-space will open a completions window. In an empty string, this will contain the files in the current directory. On a blank line, it will contain the built-in and user-defined functions and classes in the current namespaces, plus any modules imported. If some characters have been entered, the ACW will attempt to be more specific.
If a string of characters is typed, the ACW selection will jump to the entry most closely matching those characters. Entering a tab will cause the longest non-ambiguous match to be entered in the Editor window or Shell. Two tab in a row will supply the current ACW selection, as will return or a double click. Cursor keys, Page Up/Down, mouse selection, and the scroll wheel all operate on the ACW.
"Hidden" attributes can be accessed by typing the beginning of hidden
name after a '.', e.g. '_'. This allows access to modules with
__all__ set, or to class-private attributes.
Completions and the 'Expand Word' facility can save a lot of typing!
Completions are currently limited to those in the namespaces. Names in
an Editor window which are not via __main__ and sys.modules will
not be found. Run the module once with your imports to correct this situation.
Note that IDLE itself places quite a few modules in sys.modules, so
much can be found by default, e.g. the re module.
If you don't like the ACW popping up unbidden, simply make the delay longer or disable the extension.
提示?
A calltip is shown when one types ( after the name of an accessible function. A name expression may include dots and subscripts. A calltip remains until it is clicked, the cursor is moved out of the argument area, or ) is typed. When the cursor is in the argument part of a definition, the menu or shortcut display a calltip.
A calltip consists of the function signature and the first line of the docstring. For builtins without an accessible signature, the calltip consists of all lines up the fifth line or the first blank line. These details may change.
The set of accessible functions depends on what modules have been imported into the user process, including those imported by Idle itself, and what definitions have been run, all since the last restart.
For example, restart the Shell and enter itertools.count(. A calltip
appears because Idle imports itertools into the user process for its own use.
(This could change.) Enter turtle.write( and nothing appears. Idle does
not import turtle. The menu or shortcut do nothing either. Enter
import turtle and then turtle.write( will work.
In an editor, import statements have no effect until one runs the file. One might want to run a file after writing the import statements at the top, or immediately run an existing file before editing.
代碼上下文?
在一個包含 Python 代碼的編輯器窗口內部,可以切換代碼上下文以便顯示或隱藏窗口頂部的面板。 當顯示時,此面板可以凍結代碼塊的開頭行,例如以 class, def 或 if 關鍵字開頭的行,這樣的行在不顯示時面板時可能離開視野。 此面板的大小將根據需要擴展和收縮以顯示當前層級的全部上下文,直至達到配置 IDLE 對話框中所定義的最大行數(默認為 15)。 如果如果沒有當前上下文行而此功能被啟用,則將顯示一個空行。 點擊上下文面板中的某一行將把該行移至編輯器頂部。
上下文面板的文本和背景顏色可在配置 IDLE 對話框的 Highlights 選項卡中進行配置。
Python Shell 窗口?
通過 IDLE 的 Shell 可以輸入、編輯和召回整條語句。 大部分控制臺和終端在同一時刻只能處理單個物理行。
當向 Shell 粘貼代碼時,它并不會被編譯和執行,直到按下 Return 鍵。 在此之前可以先編輯所粘貼的代碼。 如果向 Shell 粘貼了多行代碼,多條語句會被當作一條語句來編譯,結果將引發 SyntaxError。
之前小節中描述的編輯功能在交互式地輸入代碼時也可使用。 IDLE 的 Shell 窗口還會響應以下按鍵。
C-c 中斷執行命令
C-d 發送文件結束命令;如果在
>>>提示符后按下會關閉窗口。Alt-/ (擴展單詞) 也有助于減少輸入量
歷史命令
Alt-p 提取與你所輸入鍵匹配的前一條命令。 在 macOS 上請使用 C-p。
Alt-n 提取下一條命令。 在 macOS 上請使用 C-n。
在任意的前一條命令上按 Return 將提取該命令
文本顏色?
IDLE 文本默認為白底黑字,但有特殊含義的文本將以彩色顯示。 對于 Shell 來說包括 Shell 輸出,Shell 錯誤,用戶輸出和用戶錯誤。 對于 Shell 提示符下或編輯器中的 Python 代碼來說則包括關鍵字,內置類和函數名稱,class 和 def 之后的名稱,字符串和注釋等。 對于任意文本窗口來說則包括光標(如果存在)、找到的文本(如果可能)和選定的文本。
廣西著色是在背景上完成的,因此有時會看到非著色的文本。 要改變顏色方案,請使用配置 IDLE 對話框的高亮選項卡。 編輯器中的調試器斷點行標記和彈出面板和對話框中的文本則是用戶不可配置的。
啟動和代碼執行?
在附帶 -s 選項啟用的情況下,IDLE 將會執行環境變量 IDLESTARTUP 或 PYTHONSTARTUP 所引用的文件。 IDLE 會先檢查 IDLESTARTUP;如果 IDLESTARTUP 存在則會運行被引用的文件。 如果 IDLESTARTUP 不存在,則 IDLE 會檢查 PYTHONSTARTUP。 這些環境變量所引用的文件是存放經常被 IDLE Shell 所使用的函數,或者執行導入常用模塊的 import 語句的便捷場所。
此外,Tk 也會在存在啟動文件時加載它。 請注意 Tk 文件會被無條件地加載。 此附加文件名為 .Idle.py 并且會在用戶的家目錄下查找。 此文件中的語句將在 Tk 的命名空間中執行,所以此文件不適用于導入要在 IDLE 的 Python Shell 中使用的函數。
命令行語法?
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)
如果有參數:
如果使用了
-,-c或r,則放在sys.argv[1:...]和sys.argv[0]中的所有參數都會被設為'','-c'或'-r'。 不會打開任何編輯器窗口,即使是在選項對話框中的默認設置。在其他情況下,參數為要打開編輯的文件而
sys.argv反映的是傳給 IDLE 本身的參數。
啟動失敗?
IDLE uses a socket to communicate between the IDLE GUI process and the user
code execution process. A connection must be established whenever the Shell
starts or restarts. (The latter is indicated by a divider line that says
'RESTART'). If the user process fails to connect to the GUI process, it
displays a Tk error box with a 'cannot connect' message that directs the
user here. It then exits.
導致連接失敗的一個常見原因是用戶創建的文件與標準庫模塊同名,例如 random.py 和 tkinter.py。 當這樣的文件與要運行的文件位于同一目錄中時,IDLE 將無法導入標準庫模塊。 可用的解決辦法是重命名用戶文件。
雖然現在已不太常見,但殺毒軟件或防火墻程序也有可能會阻止連接。 如果無法將此類程序設為允許連接,那么為了運行 IDLE 就必須將其關閉。 允許這樣的內部連接是安全的,因為數據在外部端口上不可見。 一個類似的問題是錯誤的網絡配置阻止了連接。
Python 的安裝問題有時會使 IDLE 退出:存在多個版本時可能導致程序崩潰,或者單獨安裝時可能需要管理員權限。 如果想要避免程序崩潰,或是不想以管理員身份運行,最簡單的做法是完全卸載 Python 并重新安裝。
有時會出現 pythonw.exe 僵尸進程問題。 在 Windows 上,可以使用任務管理員來檢查并停止該進程。 有時由程序崩潰或鍵盤中斷(control-C)所發起的重啟動可能會出現連接失敗。 關閉錯誤提示框或使用 Shell 菜單中的 Restart Shell 可能會修復此類臨時性錯誤。
當 IDLE 首次啟動時,它會嘗試讀取 ~/.idlerc/ 中的用戶配置文件(~ 是用戶的家目錄)。 如果配置有問題,則應當顯示一條錯誤消息。 除隨機磁盤錯誤之外,此類錯誤均可通過不手動編輯這些文件來避免。 請使用 Options 菜單來打開配置對話框。 一旦用戶配置文件出現錯誤,最好的解決辦法就是刪除它并使用配置對話框重新設置。
如果 IDLE 退出時沒有發出任何錯誤消息,并且它不是通過控制臺啟動的,請嘗試通過控制臺或終端 (python -m idlelib) 來啟動它以查看是否會出現錯誤消息。
運行用戶代碼?
With rare exceptions, the result of executing Python code with IDLE is
intended to be the same as executing the same code by the default method,
directly with Python in a text-mode system console or terminal window.
However, the different interface and operation occasionally affect
visible results. For instance, sys.modules starts with more entries,
and threading.activeCount() returns 2 instead of 1.
在默認情況下,IDLE 會在單獨的 OS 進程中運行用戶代碼而不是在運行 Shell 和編輯器的用戶界面進程中運行。 在執行進程中,它會將 sys.stdin, sys.stdout 和 sys.stderr 替換為從 Shell 窗口獲取輸入并向其發送輸出的對象。 保存在 sys.__stdin__, sys.__stdout__ 和 sys.__stderr__ 中的原始值不會被改變,但可能會為 None。
當 Shell 獲得焦點時,它將控制鍵盤與屏幕。 這通常會保持透明,但一些直接訪問鍵盤和屏幕的函數將會不起作用。 這也包括那些確定是否有鍵被按下以及是哪個鍵被按下的系統專屬函數。
IDLE 的標準流替換不會被執行進程中創建的子進程所繼承,不論它是由用戶代碼直接創建還是由 multiprocessing 之類的模塊創建的。 如果這樣的子進程使用了 input 獲取 sys.stdin 或者使用了 print 或 write 輸出到 sys.stdout 或 sys.stderr,則應當在命令行窗口中啟動 IDLE。 這樣二級子進程將會被附加到該窗口進行輸出和輸出。
在執行進程中運行的 IDLE 代碼會向調用棧添加在其他情況下不存在的幀。 IDLE 包裝了 sys.getrecursionlimit 和 sys.setrecursionlimit 以減少額外棧幀的影響。
如果 sys 被用戶代碼重置,例如使用了 importlib.reload(sys),則 IDLE 的修改將丟失,來自鍵盤的輸入和向屏幕的輸出將無法正確運作。
當用戶代碼直接或者通過調用 sys.exit 引發 SystemExit 時,IDLE 將返回 Shell 提示符而非完全退出。
Shell中的用戶輸出?
當一個程序輸出文本時,結果將由相應的輸出設備來確定。 當 IDLE 執行用戶代碼時,sys.stdout 和 sys.stderr 會被連接到 IDLE Shell 的顯示區。 它的某些特性是從底層的 Tk Text 部件繼承而來。 其他特性則是程序所添加的。 總之,Shell 被設計用于開發環境而非生產環境運行。
例如,Shell 絕不會丟棄輸出。 一個向 Shell 發送無限輸出的程序將最終占滿內存,導致內存錯誤。 作為對比,某些系統文本模式窗口只會保留輸出的最后 n 行。 例如,Windows 控制臺可由用戶設置保留 1 至 9999 行,默認為 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 函數會被用于表達式值的交互式回顯。 它將返回輸入字符串的一個修改版本,其中的控制代碼、部分 BMP 碼位以及所有非 BMP 碼位都將被替換為轉義代碼。 如上面所演示的,它使用戶可以辨識字符串中的字符,無論它們會如何顯示。
普通的與錯誤的輸出通常會在與代碼輸入和彼此之間保持區分 (顯示于不同的行)。 它們也會分別使用不同的高亮顏色。
對于 SyntaxError 回溯信息,表示檢測到錯誤位置的正常 '^' 標記被替換為帶有代表錯誤的文本顏色高亮。 當從文件運行的代碼導致了其他異常時,用戶可以右擊回溯信息行在 IDLE 編輯器中跳轉到相應的行。 如有必要將打開相應的文件。
Shell 具有將輸出行折疊為一個 'Squeezed text' 標簽的特殊功能。 此功能將自動應用于超過 N 行的輸出 (默認 N = 50)。 N 可以在設置對話框中 General 頁的 PyShell 區域中修改。 行數更少的輸出也可通過在輸出上右擊來折疊。 此功能適用于過多的輸出行數導致滾動操作變慢的情況。
已折疊的輸出可通過雙擊該標簽來原地展開。 也可通過右擊該標簽將其發送到剪貼板或單獨的查看窗口。
開發 tkinter 應用程序?
IDLE 有意與標準 Python 保持區別以方便 tkinter 程序的開發。 在標準 Python 中輸入 import tkinter as tk; root = tk.Tk() 不會顯示任何東西。 在 IDLE 中輸入同樣的代碼則會顯示一個 tk 窗口。 在標準 Python 中,還必須輸入 root.update() 才會將窗口顯示出來。 IDLE 會在幕后執行同樣的方法,每秒大約 20 次,即每隔大約 50 毫秒。 下面輸入 b = tk.Button(root, text='button'); b.pack()。 在標準 Python 中仍然不會有任何可見的變化,直到輸入 root.update()。
大多數 tkinter 程序都會運行 root.mainloop(),它通常直到 tk 應用被銷毀時才會返回。 如果程序是通過 python -i 或 IDLE 編輯器運行的,則 >>> Shell 提示符將直到 mainloop() 返回時才會出現,這時將結束程序的交互。
當通過 IDLE 編輯器運行 tkinter 程序時,可以注釋掉 mainloop 調用。 這樣將立即回到 Shell 提示符并可與正在運行的應用程序交互。 請記得當在標準 Python 中運行時重新啟用 mainloop 調用。
在沒有子進程的情況下運行?
By default, IDLE executes user code in a separate subprocess via a socket, which uses the internal loopback interface. This connection is not externally visible and no data is sent to or received from the Internet. If firewall software complains anyway, you can ignore it.
如果創建套接字連接的嘗試失敗,IDLE 將會通知你。 這樣的失敗可能是暫時性的,但是如果持續存在,問題可能是防火墻阻止了連接或某個系統配置錯誤。 在問題得到解決之前,可以使用 -n 命令行開關來運行 IDLE。
如果 IDLE 啟動時使用了 -n 命令行開關則它將在單個進程中運行并且將不再創建運行 RPC Python 執行服務器的子進程。 這適用于 Python 無法在你的系統平臺上創建子進程或 RPC 套接字接口的情況。 但是,在這種模式下用戶代碼沒有與 IDLE 本身相隔離。 而且,當選擇 Run/Run Module (F5) 時運行環境也不會重啟。 如果你的代碼已被修改,你必須為受影響的模塊執行 reload() 并重新導入特定的條目 (例如 from foo import baz) 才能讓修改生效。 出于這些原因,在可能的情況下最好還是使用默認的子進程來運行 IDLE。
3.4 版后已移除.
幫助和偏好?
幫助資源?
Help 菜單項 "IDLE Help" 會顯示標準庫參考中 IDLE 一章的帶格式 HTML 版本。 這些內容放在只讀的 tkinter 文本窗口中,與在瀏覽器中看到的內容類似。 可使用鼠標滾輪、滾動條或上下方向鍵來瀏覽文本。 或是點擊 TOC (Table of Contents) 按鈕并在打開的選項框中選擇一個節標題。
Help 菜單項 "Python Docs" 會打開更豐富的幫助源,包括教程,通過 docs.python.org/x.y 來訪問,其中 'x.y' 是當前運行的 Python 版本。 如果你的系統有此文檔的離線副本 (這可能是一個安裝選項),則將打開這個副本。
選定的 URL 可以使用配置 IDLE 對話框的 General 選項卡隨時在幫助菜單中添加或移除。
偏好設定?
The font preferences, highlighting, keys, and general preferences can be
changed via Configure IDLE on the Option menu.
Non-default user settings are saved in a .idlerc directory in the user's
home directory. Problems caused by bad user configuration files are solved
by editing or deleting one or more of the files in .idlerc.
On the Font tab, see the text sample for the effect of font face and size on multiple characters in multiple languages. Edit the sample to add other characters of personal interest. Use the sample to select monospaced fonts. If particular characters have problems in Shell or an editor, add them to the top of the sample and try changing first size and then font.
On the Highlights and Keys tab, select a built-in or custom color theme and key set. To use a newer built-in color theme or key set with older IDLEs, save it as a new custom theme or key set and it well be accessible to older IDLEs.
macOS 上的IDLE?
Under System Preferences: Dock, one can set "Prefer tabs when opening documents" to "Always". This setting is not compatible with the tk/tkinter GUI framework used by IDLE, and it breaks a few IDLE features.
擴展?
IDLE contains an extension facility. Preferences for extensions can be changed with the Extensions tab of the preferences dialog. See the beginning of config-extensions.def in the idlelib directory for further information. The only current default extension is zzdummy, an example also used for testing.
