- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个 PowerShell 脚本可以将我们的 Windows 10 计算机升级到更新的功能更新。该脚本还会在某些步骤进行时记录它们,以便我们可以跟踪它们。但是,实际的升级步骤需要几个小时,并且(目前)在完成之前无法看到它的进展。这是我到目前为止所拥有的:
Get-Content -Path "C:\$WINDOWS.~BT\Sources\Panther\setupact.log" -Tail 0 -Wait | Where {$_ -Match "Mapped\ Global\ progress:\ \[10%]"}
Add-Content -Path "\\SERVER1\Logs\Upgrade.log" -Value "Upgrade stage is at 10% progress"
Get-Content -Path "C:\$WINDOWS.~BT\Sources\Panther\setupact.log" -Tail 0 -Wait | Where {$_ -Match "Mapped\ Global\ progress:\ \[20%]"}
Add-Content -Path "\\SERVER1\Logs\Upgrade.log" -Value "Upgrade stage is at 20% progress"
这是有效的,因为当脚本看到 setupact.log 中出现“Mapped Global Progress: 10%”值时更新 Upgrade.log,但问题是它停在那里并且不会检测到任何进一步的更新。我认为这是因为
-wait
参数添加到
Get-Content
命令。
最佳答案
这是一种您可以使用 C# 编写的 .NET 类来实现的方法。它使用一个名为 LogFileMonitor 的类,我们首先使用 Add-Type
定义它。 .
一旦类型被加载,我们就可以创建它的一个实例。它的构造函数接受将被监控的日志路径和一个 TimeSpan,用于定义我们想要检查日志中更新的频率。在下面的代码中,它被设置为每秒。
接下来我们订阅两个可用事件之一:LineAdded 或 LinesAdded。我选择使用 LinesAdded ,它每秒仅引发 1 个事件(或我们选择的任何时间跨度)并返回包含自上次检查以来添加的所有行的行列表。我们将在我们的行动中单独检查这些。
(另一个 LineAdded 将为每添加一行并提供单行引发 1 个事件。如果在最后一秒添加 10 行,则将引发 10 个事件,每行 1 行。)
订阅时,我们需要定义当我们订阅的事件被引发时我们想要执行的操作。这是我们检查匹配行并更新其他日志的地方。我决定在这里使用带有 -regex 选项的开关。当我们的任何行与我们列出的正则表达式模式之一匹配时,将执行脚本块,将内容添加到另一个日志(或我们定义的任何其他操作)
Add-Type -TypeDefinition @'
using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Threading.Tasks;
namespace CustomClasses
{
public class LogFileMonitor
{
private DateTime _lastWriteTime;
private int _lineCount;
private TimeSpan _checkInterval = new TimeSpan(0, 0, 5);
public string Path { get; }
public bool Active { get; private set; } = false;
public LogFileMonitor(string path)
{
if (String.IsNullOrEmpty(path))
{
throw new ArgumentNullException("path");
}
if (!File.Exists(path))
{
throw new FileNotFoundException("Could not find file", path);
}
Path = path;
_lastWriteTime = File.GetLastWriteTime(path);
_lineCount = File.ReadAllLines(path).Length;
}
public LogFileMonitor(string path, TimeSpan interval) : this(path)
{
_checkInterval = interval;
}
public event EventHandler<LineAddedEventArgs> LineAdded;
public event EventHandler<LinesAddedEventArgs> LinesAdded;
protected virtual void OnLineAdded(LineAddedEventArgs e)
{
EventHandler<LineAddedEventArgs> handler = LineAdded;
if (handler != null)
{
handler(this, e);
}
}
protected virtual void OnLinesAdded(LinesAddedEventArgs e)
{
EventHandler<LinesAddedEventArgs> handler = LinesAdded;
if (handler != null)
{
handler(this, e);
}
}
public virtual async Task StartMonitoring()
{
if (!Active)
{
Active = true;
await Task.Run(() =>
{
do
{
DateTime currentLastWriteTime = File.GetLastWriteTime(Path);
if (_lastWriteTime != currentLastWriteTime)
{
try
{
var lines = File.ReadAllLines(Path);
_lastWriteTime = currentLastWriteTime;
if (lines.Length > _lineCount)
{
var linesAddedArgs = new LinesAddedEventArgs()
{
Lines = lines.Skip(_lineCount).ToList<string>()
};
OnLinesAdded(linesAddedArgs);
int newLineNumber = 0;
foreach (string line in lines.Skip(_lineCount))
{
var lineAddedArgs = new LineAddedEventArgs()
{
Line = line,
LineNumber = _lineCount + ++newLineNumber
};
OnLineAdded(lineAddedArgs);
}
_lineCount = lines.Length;
}
else if (lines.Length < _lineCount)
{
_lineCount = lines.Length;
}
}
catch (IOException)
{
// Log file likely being written to
}
}
Task.Delay((int)_checkInterval.TotalMilliseconds).Wait();
} while (Active);
});
Active = false;
}
else
{
throw new InvalidOperationException("Monitoring is already active. Subscribe to 'LineAdded' Event.");
}
}
public virtual void StopMonitoring()
{
Active = false;
}
}
}
public class LineAddedEventArgs : EventArgs
{
public int LineNumber { get; set; }
public string Line { get; set; }
public DateTime Time { get; } = DateTime.Now;
}
public class LinesAddedEventArgs : EventArgs
{
public List<string> Lines { get; set; }
public DateTime Time { get; } = DateTime.Now;
}
'@
$logBeingMonitored = 'C:\$WINDOWS.~BT\Sources\Panther\setupact.log'
$logProgress = '\\SERVER1\Logs\Upgrade.log'
$monitor = New-Object CustomClasses.LogFileMonitor -ArgumentList @($logBeingMonitored, [timespan]::new(0, 0, 1))
$subscriber = Register-ObjectEvent -InputObject $monitor -EventName LinesAdded -SourceIdentifier MyScript -Action {
switch -regex ($eventargs.lines) {
'Mapped\ Global\ progress:\ \[10%]' {
Add-Content -Path $logProgress -Value 'Upgrade stage is at 10% progress'
}
'Mapped\ Global\ progress:\ \[20%]' {
Add-Content -Path $logProgress -Value 'Upgrade stage is at 20% progress'
}
Default {}
}
}
$task = $monitor.StartMonitoring()
关于用于监视日志并将进度输出到另一个的 PowerShell 脚本,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/68841535/
我正在开发一个在 gridview 中显示数据表内容的网页。而且,还有一个名为“发送到 Excel”的按钮。如果用户单击此按钮,该程序将开始生成报告(将数据表内容写入 excel 文件)。完成后,会出
理论:我在开始时做出了大约 100 个 promise ,然后使用 Promise.all() 解决它们。 这 100 个 promise 中的每一个依次进行一些异步 REST 调用,其响应可能主要不
在将文件添加到 python 中的 tar 存档时,是否有任何库可以显示进度,或者可以扩展 tarfile 模块的功能来执行此操作? 在理想情况下,我想展示 tar 创建的总体进度以及关于何时完成的预
有没有办法在 Xcode 中更改进度 View 栏的高度? 我正在使用 Xcode 4.3 并且需要一个垂直进度条。我旋转了栏,但现在无法更改高度并且显示为一个圆圈。 还有一种更有效的旋转进度条的方法
您好,我想在栏按钮项上制作未确定的进度 View 。完成后我想让它隐藏,但 hidden() 方法没有像 disabled(Bool) 这样的参数。任务完成后如何隐藏进度 View ? 这就是我要的
我有一个管理员控制的功能(导入数据库)可能需要一些时间才能完成,所以我想在这段时间内向用户显示一些反馈 - 例如进度条,或者只是一些消息。即使在长时间的 Action 中分部分发送页面也足够了。 在
我是一个进步的菜鸟,实际上在基本 block 方面有问题。 下面的问题是在我的 if else 语句中。它在 if, then, else then 时工作正常,但是当我想将多个语句放入 if 部分时
我有一个来自 rsync 命令的日志文件,其中有进度。运行此进度时,会更新同一行上的显示信息。当我捕获此命令的输出时,我得到一个在终端上使用 cat 正常显示的文件(重播所有退格键和重新编辑)但我希望
我需要处理一些数据,每 5-10 秒显示一个进度(我以 % 显示进度,但我也更新了一些图表)。我想在没有多线程的情况下做到这一点。 循环可能相当大。它可以从数百万开始,可以高达数十亿。 我可以使用 G
我正在致力于使用 PHP、HTML 和 JavaScript 制作半直播互联网 channel 。 您可以在此处查看演示:http://mariocreative.host/chanelko/inde
我实际上正在使用图像为“点点点”进度设置动画。我想通过使用下面的代码来使用不透明度。 动画将持续 3 秒,有没有更简单的动画方法? 最佳答案 这是一个快速版本,它会在控
我写了这个程序,它返回用户插入的最大整数。现在,我希望程序返回第二大整数。我创建了一个新变量(称为“状态”),该变量应该在每次循环重复时增加 1 个单位。然后,在中断条件发生后,我将在状态变量中后退
我正在制作一个需要保存进度的java游戏。但我不想让外部文件保存进度(像《我的世界》这样的游戏有一个存储文件的“保存”目录)。所以基本上我希望它存储一些数据,当用户退出并再次返回时可以检索这些数据。比
我正在使用 forEach_root 方法在 Android 上计算图像。 RenderScript RS=RenderScript.create(context); Allocation inPix
我希望这个进度 View 在完成后基本上“重置”。 尝试将计数重置为 0,它确实重置了,但是对于每次重置,计时器只会变得越来越快。 .h @property (nonatomic, strong) N
我不确定这是否可能。当您单击“提交”按钮时,似乎有一种方法可以做到这一点。 private Button getButton(String id) { return new AjaxButto
我找不到关于如何在迭代循环时更新 UIProgressbar 进度的明确答案,例如: for (int i=0;i
我正在尝试在 Xcode 中翻转 UIProgressView 180,同时我正在尝试缩放进度 View 。在我添加翻转之前缩放效果很好,然后缩放不再起作用。有什么建议么?谢谢! [self.seco
我目前正在通过评估 prepareForSegue 中的 segue.identifier 动态加载新 View : - (void)prepareForSegue:(UIStoryboardSegu
当任意进程发生时,我需要在屏幕上为用户提供状态。我无法知道需要多长时间。我怎样才能永远增加 progressView (当它接近 1 时它会减慢)。 最佳答案 This如果您愿意更换进度 View ,
我是一名优秀的程序员,十分优秀!