0

我有一个大文件,我正在搜索它以查找和替换无效日期。我正在使用 REGEX 表达式来定位日期,然后确定它们是否有效。如果脚本发现无效日期,则需要将日期替换为当前日期。出于审计目的,我需要记录无效字符串和发现错误的行号。到目前为止(在 SO 的一些事先帮助下)我已经能够找到无效的日期,但我无法成功地更改它们。

这是我用来定位无效日期的代码。如何一次性定位和更改日期?

$matchInfos = @(Select-String -Pattern $regex -AllMatches -Path $file)
foreach ($minfo in $matchInfos)
{
    #"LineNumber $($minfo.LineNumber)"
    foreach ($match in @($minfo.Matches | Foreach {$_.Groups[0].value}))
    {
        if (([Boolean]($match -as [DateTime]) -eq $false ) -or ([DateTime]::parseexact($match,"MM-dd-yyyy",$null).Year -lt "1800")) {
            Write-host "Invalid date on line $($minfo.LineNumber) - $match"
            #Add-Content -Path $LOGFILE -Value "Invalid date on line $($minfo.LineNumber) - $match"

            # Replace the invalid date with a corrected one
            Write-Host "Replacing $match with $(Get-Date -Format "MM-dd-yyyy")"
            #Add-Content -Path $LOGFILE -Value "Replacing $match with $(Get-Date -Format "MM-dd-yyyy")"

        }
    }
 }
4

2 回答 2

1
$lines = get-content $file
$len = $lines.count
$bad = @{}
for($i=0;$i-lt$len;$i++){
    if($lines[$i] -match ""){
        $bad_date = $lines[$i].substring(10) #Get the bad date
        $good_date = Get-Date -Format G
        $bad["$i"] += @($line[$i])
        $lines[$i] = $lines[$i].Replace($bad_date,$good_date)
    }
}
$lines > $NewFile
$bad > $bad_date_file

这是我将如何解决这个问题的一些伪代码。不确定你的文件有多大。阅读和写作可能很慢。

于 2013-02-28T20:53:48.140 回答
1

您必须用更改写出一个临时文件,并用临时文件替换该文件。这是我写的一篇文章,它将为你完成这部分:

Windows IT Pro:使用 PowerShell 替换文件中的字符串

使用示例:

replace-filestring -pattern 'find' -replacement 'replace' -path myfile.txt -overwrite

使用此命令,脚本将读取 myfile.txt,将 'find' 替换为 'replace',将输出写入临时文件,然后将 myfile.txt 替换为临时文件。(如果没有-Overwrite参数,脚本只会输出 myfile.txt 的内容以及更改。)

账单

于 2013-02-28T20:38:41.523 回答