我进行了搜索,但只找到了与 excel 相关的答案。
目标:
计算原始音频 LUFS 值与用户定义的 LUFS 值之间的差异。这两个值都是负数,我使用一个运算来计算这两个值之间的差异,其中所有减法结果小于 -0.5 的音频都将被忽略。
注:
1 - 通过音频日志检查原始 LUFS 值;
2 - 用户定义的 LUFS 值由 powershell 脚本通过参数接收。
脚本:
Param(
[decimal]$env:_vLUF
)
[decimal]$userLUFS = $env:_vLUF
$results = " "
$location = "C:\Users\$env:username\Desktop\Áudios LUFS\"
$logSaida = "C:\Users\$env:username\Desktop\Logs_LUFS\"
$logMatches = Select-String -Path "C:\Users\$env:username\Desktop\Logs_LUFS\*.*" -Pattern '(?<I>^ +I:) +(?<LUFS>.+)|(?<I>^Input Integrated:) +(?<LUFS>.+)' -List | Select-Object -Property FileName -ExpandProperty Matches
$results = foreach ($log in $logMatches) {
$pos = $log.Filename.IndexOf("_")
$leftPart = $log.Filename.Substring(0, $pos)
$rightPart = $log.Filename.Substring($pos+1)
$LUFS = $log.Groups | Where-Object { $_.Name -eq "LUFS" }
[PSCustomObject]@{
Música = $rightPart
LUFS = [decimal]$($LUFS.Value -replace " .*")
}
}
# COMMAND to the subtraction:
$results | Where-Object {( ($_.LUFS -($userLUFS)) -lt -0.5)} | Out-File $files
问题:
当原始LUFS值大于用户定义的LUFS值时,减法正确,见下图:
原始 LUFS ($_.LUFS):- 12.0
用户定义的 LUFS ($userLUFS):-8.8
当用户定义的值大于原始 LUFS 值时,即使两个值都是负数,减法也会在结果中返回正值,见下文:
原始 LUFS ($_.LUFS):-8.8
用户定义的 LUFS ($userLUFS):- 12.0
似乎因为值是负数,它认为 -8.8 大于 -12.0 因为它更接近 0.0,但我想要的是结果,无论接收到的值的顺序如何,总是返回负数结果。我尝试将结果乘以 -1,但它只是扭转了问题。如何使结果始终返回负值?
-8.8在数学上大于 -12.0。
你可以使用
无条件地获得负值(或在适用的情况下为零)。