Unbuffer 几个月前停止工作

Sta*_*man 9 package-management apt expect 16.04 18.04

我发现“unbuffer”命令非常重要和有用,因为我正在运行 python 代码,而且我认为我不能在任何地方放置与 fflush() 等效的东西。

我以前用的很好: unbuffer python foo.py | tee filename.log

几个月前,我不确定我是否允许我的 Ubuntu 16.04 自动更新某些软件,但它停止工作。

$ unbuffer
can't find package Expect
    while executing
"package require Expect"
    (file "/usr/bin/unbuffer" line 6)
Run Code Online (Sandbox Code Playgroud)

我尝试编辑一些文件并更改Expect为小写,expect但没有用。

我尝试(几个月前)使用 apt-get 工具卸载并重新安装 Expect,但无济于事。我很惊讶我不能谷歌这个并发现其他人抱怨它不起作用。

我刚刚在朋友的 18.04 Ubuntu 上尝试过。他从未使用过它,他用 apt-get 下载了它并得到了同样的失败信息。任何帮助表示赞赏。

感谢@pynexj 对 cat /usr/bin/unbuffer 的建议:

#!/bin/sh
# -*- tcl -*-
# The next line is executed by /bin/sh, but not tcl \
exec tclsh8.6 "$0" ${1+"$@"}

package require expect


# -*- tcl -*-
# Description: unbuffer stdout of a program
# Author: Don Libes, NIST

if {[string compare [lindex $argv 0] "-p"] == 0} {
    # pipeline
    set stty_init "-echo"
    eval [list spawn -noecho] [lrange $argv 1 end]
    close_on_eof -i $user_spawn_id 0
    interact {
    eof {
        # flush remaining output from child
        expect -timeout 1 -re .+
        return
    }
    }
} else {
    set stty_init "-opost"
    set timeout -1
    eval [list spawn -noecho] $argv
    expect
    exit [lindex [wait] 3]
}
Run Code Online (Sandbox Code Playgroud)

我一直在这台机器上使用 conda,但我在一个终端中运行这些测试,而我没有做过任何source activate. 如果重要的话,我路径中的第一项是 /home/myusername/anaconda3/bin 。

$ apt list --installed | grep -i expect

WARNING: apt does not have a stable CLI interface. Use with caution in scripts.

expect/xenial,now 5.45-7 amd64 [installed]
python3-pexpect/xenial,xenial,now 4.0.1-1 all [installed]
tcl-expect/xenial,now 5.45-7 amd64 [installed,automatic]

$ locate '*expect*pkgIndex.tcl'
/usr/lib/tcltk/x86_64-linux-gnu/expect5.45/pkgIndex.tcl
Run Code Online (Sandbox Code Playgroud)

谢谢@glenn jackman,我发现我tclsh在 ~/anaconda3/bin/tclsh 并指向 tclsh8.6 我猜这意味着它是作为我的 conda 安装的一部分安装的。如上所述,anaconda3/bin 位于我的 PATH 的顶​​部。我自己没有建造任何东西。

我们知道 8.6 是旧的还是新的吗?我应该尝试在 tcl 或 tclsh 上进行 apt-get 更新,在 conda 之外,看看是否有帮助?

bre*_*zky 12

我相信遇到了完全相同的问题,主要是由安装 Anaconda 引起的。看起来我的系统正在转向 Anaconda 自带的东西,而不是很久以前安装的东西——否则仍然存在。

按照https://anaconda.org/Eumetsat/expect,我只需要发出一个

conda install -c eumetsat expect
Run Code Online (Sandbox Code Playgroud)

使事情恢复秩序。