- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我在管道中使用 pv
命令来显示进度条。我用一个简单的计数器试了一下:
for (( i = 1 ; i <= 100 ; i++ )); do sleep 1; echo $i; done | pv --progress --line-mode --size 100 --eta --timer
这工作正常,但我希望进度条显示在同一行上。 This answer解释了如何做到这一点。
所以我试了一下:
for (( i = 1 ; i <= 100 ; i++ )); do sleep 1; echo $i; done | >&2 echo -en "\r"; pv --progress --line-mode --size 100 --eta --timer
它保持在一行,但现在不再更新 ETA。
我怎样才能让 ETA 也更新?
现在 iBug answered the question从上一节中,我意识到我还有一个相关的要求:需要保留 stdout
以便在下一个管道中使用它。在我的具体情况下,我需要将结果写入文件(即 > some-file.txt
)
最佳答案
你输入了错误的命令。
for (( i = 1 ; i <= 100 ; i++ )); do sleep 1; echo $i; done | >&2 echo -en "\r"; pv --progress --line-mode --size 100 --eta --timer
^
pv
之前有一个分号,所以您实际上是在 stdin/stdout 上运行它,这是您的终端。您应该将额外的 echo
和 pv
分组,让它从 for
循环中读取:
for (( i = 1 ; i <= 100 ; i++ )); do sleep 1; echo $i; done | (>&2 echo -en "\r"; pv --progress --line-mode --size 100 --eta --timer)
为什么第一个命令不是这种情况?这是因为整个 for do done
子句被视为单个命令,所以它的结果正确地通过管道传输到 pv
。然而,在第二个命令中,结果通过管道传输到 echo
。您知道,echo
不会从标准输入中读取任何内容。
因为 pv
将 stdin 定向到 stdout,数字也会输出到终端,这与 stderr 的指示混合在一起。要抑制正常输出,将其重定向到/dev/null
,所以最后的命令是
for (( i = 1 ; i <= 100 ; i++ )); do sleep 1; echo $i; done | (>&2 echo -en "\r"; pv --progress --line-mode --size 100 --eta --timer) > /dev/null
如果要将输出重定向到文件,只需在命令末尾更改 /dev/null
。
关于linux - 进度条 + ETA 与 pv 命令在同一行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47813665/
问题的标题是我收到的错误的原因是因为我根本不知道如何解释它,无论我做了多少研究。每当我使用 bigglm() (来自 biglm 包,旨在对大量数据运行回归)运行逻辑回归时,我得到: Error in
我正在创建一个 eta 范围在 3 到 20 小时之间的任务,当我查看工作日志时,对于这个任务,工作人员说“从经纪人那里得到任务:...”收到原始任务后每小时,直到达到 eta。 我知道这与设置 BR
我有一个简单的功能: calculate :: Int -> Int -> Int calculate x y = sum . filter even $ enumFromTo x y 可以简化为 c
我正在为一个气象站进行项目,但是我陷入了估计到达时间(ETA)的问题,因此,我还想应用一种方法来估计特定地点的云到达时间,例如,我将有一个太阳能站,然后会有云,但是在它们到达太阳能站之前,我想计算到达
我只从 eta expansion 中找到了一些间接线索 SimpleExpr ::= SimpleExpr1 `_' The expression 𝑒 _ is well-formed if 𝑒
我有一个简单的功能: calculate :: Int -> Int -> Int calculate x y = sum . filter even $ enumFromTo x y 可以简化为 c
在 Debian Squeeze 上,我有一个文件正在从 . 复制到 ./copy。如果我运行 watch du,我可以看到两个目录的大小随时间变化。我如何解析 du 的输出,以便我可以看到文件副本的
我收到 eta 减少以下 lambda 表达式的警告。 \(DataType arg1 arg2) -> DataType (modify arg1) arg2 互联网告诉我减少 eta 的方法是省去
我正在尝试 η-reduce 函数 foldr :: (a -> b -> b) -> b -> BinaryTree a -> b foldr combiner base tree = foldMa
我正在寻找使用线性进度信息计算操作(IE:文件下载)的 ETA 的最佳方法。 假设我有以下方法被调用: void ReportProgress(double position, double tota
更新 1: 下面提供的一些解决方案看起来不错。但是,我只知道循环在其父循环的迭代确定后迭代的次数。所以我不能事先计算所有的迭代。 原问题: 我在一个类似的程序中嵌入了循环: 程序 1: using S
我在玩 van Laarhoven 镜头时遇到了一个问题,即类型检查器拒绝了良好类型函数的 eta 缩减形式: {-# LANGUAGE RankNTypes #-} import Control.A
有人可以帮助我理解这一点/指向我一些阅读 Material 吗?以下工作正常: type F a b = Functor f => f a -> f b fComp :: F b c -> F a b
我正在用 haskell 解决一个非常基本的问题。我试图计算字符串中小写字母的数量。我的解决方案是这样的 import Data.Char lowercaseCount :: String -> In
我想安排一个任务在未来的不同时间运行。我试图在调用任务时使用 eta 选项来执行此操作。这部分本身工作得很好,但同时,我想对任务进行速率限制。我无法同时完成这两件事:安排任务在将来运行,同时也让 ce
下面的代码几乎是不言自明的: class EtaExpansionOnNonMethods { // or object val zero = 0 val zeroEta = zero
我的代码中有这一行 lev_similarity = -1*np.array([[distance.levenshtein(w1,w2) for w1 in words] for w2 in word
当前代码: def chained_task(foo, bar, start_time): return chain(task1.s(foo, bar), task2.s(eta=start_
(here 是我目前工作的要点。) Coq 带有一个关于 eta 减少的规则,允许我们证明如下内容: Variables X Y Z : Type. Variable f : X -> Y -> Z.
Eta-conversion 正在考虑函数 (x) => f(x)与函数 f 相同.在工作中重构代码时,我试图使用这种等效性来简化一些高阶函数调用。然而,事情并没有完全解决,而且我对实际发生的事情有些
我是一名优秀的程序员,十分优秀!