gpt4 book ai didi

.net - Seek 方法在 Powershell 脚本中不起作用

转载 作者:行者123 更新时间:2023-12-02 03:55:15 25 4
gpt4 key购买 nike

我正在尝试使用 .net API 来查找大型数据文件。由于某种原因我无法让它发挥作用。这是我的代码:

function check_logs{
$pos = 8192
$count = 1
$path = 'C:\Program Files\Microsoft SQL Server\MSSQL10.MSSQLSERVER\MSSQL\Log\ERRORLOG.2'
$br = 0
$reader = [System.IO.File]::OpenText($path)
$reader.DiscardBufferedData()
$reader.BaseStream.Seek(0, [System.IO.SeekOrigin]::Begin)
for(;;){
$line = $reader.ReadLine()
if($line -ne $null){$br = $br + [System.Text.Encoding]::UTF8.GetByteCount($line)}
if($line -eq $null -and $count -eq 0){break}
if($line -eq $null){$count = 0}
elseif($line.Contains(' Error:')){
Write-Host "$line $br"
}
}

}

如果我使用0作为seek方法的参数,它会按预期从头开始查找,但它也会在写入读取的行之前将0写入控制台。示例:

 0
2011-08-31 09:26:36.31 Logon Error: 17187, Severity: 16, State: 1. 4101
2011-08-31 09:26:36.32 Logon Error: 17187, Severity: 16, State: 1. 4489
2011-08-31 09:26:38.25 Logon Error: 17187, Severity: 16, State: 1. 4929
2011-08-31 09:26:38.25 Logon Error: 17187, Severity: 16, State: 1. 5304
2011-08-31 09:26:43.75 Logon Error: 17187, Severity: 16, State: 1. 6120

如果我尝试使用 4096 而不是 0 进行查找,它只会写出:

4096

我原以为除了前两行之外,它会写出与第一行相同的行。

有人能看到这个问题吗?我还有另一个问题让我想到了这一点。有关更多背景信息,请参阅 this

编辑:仍在尝试解决这个问题。有谁知道我还可以在哪里找到有关此问题的信息?是否可以向 Microsoft 脚本人员发送问题?

致以诚挚的问候

吉斯利

最佳答案

Seek 方法返回流中的新位置,这就是您打印出数字的原因。

至于为什么你没有得到输出:

  1. 确认文件大小大于 4K。
  2. 尝试打印所有行,而不是仅打印包含“Error”一词的行。这可能会给你一个线索
  3. StreamReader 是基本流的缓冲包装器,因此 Seek 和 Position 可能不会像您期望的那样工作。考虑http://geekninja.blogspot.com/2007/07/streamreader-annoying-design-decisions.html 。尝试在搜索之前添加对$reader.DiscardBufferedData()的调用。

关于.net - Seek 方法在 Powershell 脚本中不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7269477/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com