IPython 8.0 釋出,Python 命令列互動工具

2022-01-13 09:00:35

IPython 是 Python 的原生互動式 shell 的增強版,可以完成許多不同尋常的任務,比如幫助實現並行化計算;主要使用它提供的互動性幫助,比如程式碼著色、改進了的命令列回撥、製表符完成、宏功能以及改進了的互動式幫助。

IPython 8.0 醞釀了許久,主要對現有程式碼庫和幾個新功能進行了改進。新功能包括在 CLI 中使用 Black 重新格式化程式碼、ghost 建議以及突出錯誤節點的更好的回溯,從而使複雜的表示式更易於偵錯。

追溯改進

之前的錯誤回溯顯示一個雜湊表(hash),用於編譯 Python AST:

In [1]: def foo():
...:     return 3 / 0
...:

In [2]: foo()
---------------------------------------------------------------------------
ZeroDivisionError                         Traceback (most recent call last)
<ipython-input-2-c19b6d9633cf> in <module>
----> 1 foo()

<ipython-input-1-1595a74c32d5> in foo()
    1 def foo():
----> 2     return 3 / 0
    3

ZeroDivisionError: division by zero

現在錯誤回溯的格式正確,會顯示發生錯誤的單元格編號:

In [1]: def foo():
...:     return 3 / 0
...:

Input In [2]: foo()
---------------------------------------------------------------------------
ZeroDivisionError                         Traceback (most recent call last)
input In [2], in <module>
----> 1 foo()

Input In [1], in foo()
    1 def foo():
----> 2     return 3 / 0

ZeroDivisionError: division by zero

第二個回溯改進是 stack_data 包的整合;在回溯中提供更智慧的資訊;它會突出顯示發生錯誤的 AST 節點,這有助於快速縮小錯誤範圍,比如

def foo(i):
    x = [[[0]]]
    return x[0][i][0]


def bar():
    return foo(0) + foo(
        1
    ) + foo(2)

呼叫 bar() 會在 IndexError 的返回行上引發一個 foo,IPython 8.0 可以告訴你索引錯誤發生在哪裡:

IndexError
Input In [2], in <module>
----> 1 bar()
        ^^^^^

Input In [1], in bar()
      6 def bar():
----> 7     return foo(0) + foo(
                            ^^^^
      8         1
         ^^^^^^^^
      9     ) + foo(2)
         ^^^^

Input In [1], in foo(i)
      1 def foo(i):
      2     x = [[[0]]]
----> 3     return x[0][i][0]
                   ^^^^^^^

^ 標記的位置在終端會高亮顯示。

第三個回溯改進是最謹慎的,但對生產力有很大影響,在回溯中的檔名後面附加一個冒號 :: 和行號:

ZeroDivisionError               Traceback (most recent call last)
File ~/error.py:4, in <module>
      1 def f():
      2     1/0
----> 4 f()

File ~/error.py:2, in f()
      1 def f():
----> 2     1/0

許多終端和編輯器具有的整合功能,允許在使用此語法時直接跳轉到錯誤相關的檔案/行

自動建議

Ptpython 允許使用者在 ptpython/config.py 中啟用自動建議功能,此功能包含豐富的程式碼補全建議,如圖:

目前,自動建議僅在 emacs 或 vi 插入編輯模式中顯示:

  • ctrl e、ctrl f 和 alt f 快捷鍵預設在 emacs 模式下工作。
  • 要在 vi 插入模式下使用這些快捷鍵,必須在 config.py 中建立自定義鍵繫結。

使用「?」和"??"檢視物件資訊

在 IPDB 中,現在可以使用「?」和」? ?「來顯示物件的資訊,在使用 IPython 提示符時也可如此操作:

ipdb> partial?
Init signature: partial(self, /, *args, **kwargs)
Docstring:
partial(func, *args, **keywords) - new function with partial application
of the given arguments and keywords.
File:           ~/.pyenv/versions/3.8.6/lib/python3.8/functools.py
Type:           type
Subclasses:

歷史範圍全域性功能

之前使用 %history 功能時使用者可以指定對談和行的範圍,例如:

~8/1-~6/5   # see history from the first line of 8 sessions ago,
            # to the fifth line of 6 sessions ago.``

或者可以指定全域性模式(global):

-g <pattern>  # glob ALL history for the specified pattern.

但無法同時指定兩者,如果使用者確實指定了範圍和全域性模式,則將使用 glob 模式(通配所有歷史記錄),並且將忽略範圍

現在此功能獲得了增強,如果使用者同時指定範圍和 glob 模式,則 glob 模式將應用於指定的歷史範圍。

 

此外,Ipython 8.0 還取消了對 Python 3.7 的支援,僅支援 3.8 以上版本。有關 Ipython 8.0 的更多新功能,可在檢視。

展開閱讀全文