使用 emacs 时代码凌乱 ipython Inferior Python

cwi*_*ind 4 python emacs ipython emacs25

我正在使用最新的 emacs25.1.1 和最新的 archlinux。

但是,当我编辑 python 脚本并使用 Ctrl-Enter 将其发送到 Inferior ipython 时,劣势 Python 向我显示了一个丑陋的杂乱代码终端指示符,例如:

Python 3.5.2 (default, Nov  7 2016, 11:31:36) 
Type "copyright", "credits" or "license" for more information.

IPython 5.1.0 -- An enhanced Interactive Python.
?         -> Introduction and overview of IPython's features.
%quickref -> Quick reference.
help      -> Python's own help system.
object?   -> Details about 'object', use 'object??' for extra details.

[JIn [1]: import numpy as np[26D
[J
[6n[JIn [2]: [8D[8C[8D[J[6n[JIn [2]: [8D[8C
Run Code Online (Sandbox Code Playgroud)

当在这个 Inferior python 中按 Enter 时,它显示:

error in process filter: Args out of range: "
^[[6n^[[0m^[[0m^[[J^[[0;38;5;28mIn [^[[0;38;5;28m: ^[[8D^[[8C[[0m^[[0m", 128
Run Code Online (Sandbox Code Playgroud)

我将 emacs 语言环境更改为:

LANG=zh_CN.UTF-8
LC_CTYPE="zh_CN.UTF-8"
LC_NUMERIC=en_US.UTF-8
LC_TIME=en_US.UTF-8
LC_COLLATE="zh_CN.UTF-8"
LC_MONETARY=en_US.UTF-8
LC_MESSAGES="zh_CN.UTF-8"
LC_PAPER=en_US.UTF-8
LC_NAME="zh_CN.UTF-8"
LC_ADDRESS="zh_CN.UTF-8"
LC_TELEPHONE="zh_CN.UTF-8"
LC_MEASUREMENT=en_US.UTF-8
LC_IDENTIFICATION="zh_CN.UTF-8"
LC_ALL=
Run Code Online (Sandbox Code Playgroud)

到:

LANG=en_US.UTF-8
LC_CTYPE="en_US.UTF-8"
LC_NUMERIC=en_US.UTF-8
LC_TIME=en_US.UTF-8
LC_COLLATE="en_US.UTF-8"
LC_MONETARY=en_US.UTF-8
LC_MESSAGES="en_US.UTF-8"
LC_PAPER=en_US.UTF-8
LC_NAME="en_US.UTF-8"
LC_ADDRESS="en_US.UTF-8"
LC_TELEPHONE="en_US.UTF-8"
LC_MEASUREMENT=en_US.UTF-8
LC_IDENTIFICATION="en_US.UTF-8"
LC_ALL=
Run Code Online (Sandbox Code Playgroud)

使用命令 $"export LANGUAGE="en_US:en" && emacs"$,对解决凌乱的代码没有帮助。

我也在 emacs 中尝试 python-mode.et 或 elpy 包,都显示相同的混乱终端代码。

进一步?python2.7也试过了,不行:

Python 2.7.12 (default, Nov  7 2016, 11:55:55) 
Type "copyright", "credits" or "license" for more information.

IPython 5.1.0 -- An enhanced Interactive Python.
?         -> Introduction and overview of IPython's features.
%quickref -> Quick reference.
help      -> Python's own help system.
object?   -> Details about 'object', use 'object??' for extra details.

[JIn [1]: import numpy as np[26D
[J
[6n[JIn [2]: [8D[8C[8D[J[6n[JIn [2]: [8D[8C
Run Code Online (Sandbox Code Playgroud)

是最新的 ipython 问题吗?

最后emacs中的消息粘贴在这里:

error in process filter: ansi-color-filter-apply: Args out of range: "Python 3.5.2 (default, Nov  7 2016, 11:31:36) 
Type \"copyright\", \"credits\" or \"license\" for more information.

IPython 5.1.0 -- An enhanced Interactive Python.
?         -> Introduction and overview of IPython's features.
%quickref -> Quick reference.
help      -> Python's own help system.
object?   -> Details about 'object', use 'object??' for extra details.

[6n[0m
[0m[J
[0m", 408
error in process filter: Args out of range: "Python 3.5.2 (default, Nov  7 2016, 11:31:36) 
Type \"copyright\", \"credits\" or \"license\" for more information.

IPython 5.1.0 -- An enhanced Interactive Python.
?         -> Introduction and overview of IPython's features.
%quickref -> Quick reference.
help      -> Python's own help system.
object?   -> Details about 'object', use 'object??' for extra details.

[6n[0m
[0m[J
[0m", 408
error in process filter: ansi-color-filter-apply: Args out of range: "[0m[0m[J[0;38;5;28mIn [[0;38;5;10;1m1[0;38;5;28m]: [0;38;5;28;1mimport[0m [0;38;5;32;1mnumpy[0m [0;38;5;28;1mas[0m [0;38;5;32;1mnp[26D[0m
[J[0m", 177
error in process filter: Args out of range: "[0m[0m[J[0;38;5;28mIn [[0;38;5;10;1m1[0;38;5;28m]: [0;38;5;28;1mimport[0m [0;38;5;32;1mnumpy[0m [0;38;5;28;1mas[0m [0;38;5;32;1mnp[26D[0m
[J[0m", 177
error in process sentinel: elpy-rpc--default-error-callback: peculiar error: "exited abnormally with code 1"
error in process sentinel: peculiar error: "exited abnormally with code 1"
error in process filter: ansi-color-filter-apply: Args out of range: #("[JIn [1]: import numpy as np[26D
[J


[6n[0m[0m[J[0;38;5;28mIn [[0;38;5;10;1m2[0;38;5;28m]: [8D[8C[0m[0m[8D[J[0m[6n[0m[0m[J[0;38;5;28mIn [[0;38;5;10;1m2[0;38;5;28m]: [8D[8C[0m" 0 38 (fontified nil) 38 39 (fontified nil)), 283
error in process filter: Args out of range: #("[JIn [1]: import numpy as np[26D
[J


[6n[0m[0m[J[0;38;5;28mIn [[0;38;5;10;1m2[0;38;5;28m]: [8D[8C[0m[0m[8D[J[0m[6n[0m[0m[J[0;38;5;28mIn [[0;38;5;10;1m2[0;38;5;28m]: [8D[8C[0m" 0 38 (fontified nil) 38 39 (fontified nil)), 283
Run Code Online (Sandbox Code Playgroud)

小智 5

我使用了来自https://github.com/jorgenschaefer/elpy/issues/992#issuecomment-249165923 的推荐。简而言之 - 添加以下代码: (setenv "IPY_TEST_SIMPLE_PROMPT" "1")到 emacs 配置文件中。


Tim*_*m X 0

从输出和错误消息来看,由于某种原因,您的设置似乎没有处理 ipython 使用的 ansi 转义序列。假设您使用的是 pythong-mode,请确保您具有以下内容

(setq python-shell-interpreter "ipython"
      python-shell-interpreter-args "-i")
Run Code Online (Sandbox Code Playgroud)

为了消除初始化文件中的其他可能的设置,我会注释掉除上述之外的所有内容,然后重试。如果它有效,那么您的设置中存在一些问题,影响了 emacs 处理 ipython 输出的 ansi 控制序列的能力。如果仍然不起作用,那么您可能需要记录错误报告。

您还可以采取一些措施来解决该问题。

  1. 尝试将 --no-color-info 开关添加到 ipython 中。这将减少 ipython 输出的控制字符数量,从而限制问题。
  2. 考虑仅使用 python 而不是 ipython 作为劣等进程。您看到的问题是由于 ipython 使用 ansi 控制字符来提供更好的 shell。然而,emacs 实际上是您的 shell,您最好让 emacs 来处理界面并只使用更简单的劣质 shell
  3. Emacs Wiki 对如何设置强大的 python 开发环境有相当详细的描述。使用简单的 ipython/python 下级进程是最基本的方法。您可能会更好地投入一些其他软件包以获得更完整的开发环境。