AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / user-23400807

RustyAndroid's questions

Martin Hope
RustyAndroid
Asked: 2025-04-16 08:32:23 +0800 CST

PowerShell - 查找系统时出现错误消息

  • 5

我编写了一个用于重启网络上计算机的脚本。它运行良好,唯一的问题是主机中会弹出错误消息。该脚本会从一个txt文件($Computers)中提取系统名称列表。我用一个我能访问的系统测试了该脚本,并在列表中添加了单词“wrench”,以模拟一个不在网络上的系统。测试脚本时,它在查找“wrench”时抛出了一条错误消息。以下是我目前脚本实际重启部分的内容:

#Actual restart portion (for privacy reasons, real file path replaced with "file-path")
#Starts by moving most recent log to archive folder
Get-ChildItem -Path "\\file-path\Computer Restarts\Logs" -Recurse -File | Move-Item -Destination "\\file-path\Computer Restarts\Logs\Archive" -Force

     #Determine script location, create new script, get current time and date
     $ScriptDir = Split-Path $script:MyInvocation.MyCommand.Path
     $Log = New-Item "\\file-path\Computer Restarts\Logs\$(Get-Date -f yyyy-MM-dd_hh-mm-ss) Restarts.txt" -ItemType File -Force
     $Date = Get-Date -Format "dd-MMM-yyyy hh:mm:ss"
     $Now = [datetime]::Now

     Clear-Host
     Write-Host `n `n `n
     Write-Host "Rebooting all computers and verifying reboot status..." `n `n
     Write-Host "Please standby, process may take up to 30 minutes..." `n `n

     Restart-Computer -ComputerName $Computers -Wait -For PowerShell -Delay 2 -Force -Timeout 1800 # Restarts all listed systems at once

     "----------------------------------Script executed on $Date----------------------------------" + "`r`n" | Out-File $Log -Append #First thing added to new log

     foreach($Computer in $Computers) #Checks each server to see if it has rebooted. Waits for confirmation before moving to next computer, skips computer if unresponsive after short time.
     {
         $LastBoot = (Get-CimInstance Win32_OperatingSystem -ComputerName $Computer -EA 0).LastBootUpTime
         $PingRequest = Test-Connection -ComputerName $Computer -Count 1 -Quiet

         if(($PingRequest -eq $true) -and ($LastBoot -gt $Now))
         {
             Add-Content -Path $Log -Value "$Computer`: Reboot Successful."
         }
         elseif ($PingRequest -eq $false)
         {
             Add-Content -Path $Log -Value "$Computer`: Computer not detected, please confirm."
         }
         else
         {
             Add-Content -Path $Log -Value "$Computer`: Restart not detected, please restart computer manually. Last detected boot up time is $LastBoot"
         }
     }

“Wrench”不会破坏脚本,据我所知,但我更希望脚本只是悄悄地处理它找不到的系统,只需将其附加到日志中,而不是在主机中抛出错误消息。

powershell
  • 1 个回答
  • 33 Views
Martin Hope
RustyAndroid
Asked: 2024-02-14 11:12:38 +0800 CST

如何让 PowerShell 将错误消息导出到 CSV?

  • 7

我正在尝试修改 PowerShell 脚本以在 CSV 文件中附加错误。一位前同事创建了一个脚本,用于从 txt 文件中获取计算机名称,浏览 Active Directory,并使用生成的分区和规范名称创建 CSV 文件(如果有帮助的话,创建 Excel 文件)。CSV 文件有三列;“Name”,直接保存txt文件中的名字;“部门”(取自 AD 中的“名称”),包含系统所属部门/部门的名称;和“CanonicalName”,它保存 AD 中显示的每个系统的完整规范名称。有时,计算机在 AD 中没有条目,它会向主机抛出一条错误消息,并且该系统将从 CSV 文件中丢失。下面是修改后的脚本,

这是我目前拥有的:

$ComputerList = Get-Content "File Path"
$Date = Get-Date -Format dd-MM-yyyy

foreach ($Computer in $ComputerList)
{
    if (@(Get-ADComputer $Computer -ErrorAction SilentlyContinue).Count) #Check if computer exists in AD
    {
       Get-ADComputer -Identity $Computer -Properties * | Select Name, @{n='Division'; e={([string]$_.o)}}, CanonicalName |
       Export-Csv "File Path" -NoTypeInformation -Append
    }
    else #Annotate if computer does not exist in AD
    {
       $NoComputer = [PSCustomObject]
       @{
          Name = $Computer
          Division = "Object Not Found"
          CanonicalName = " "
       }
       
       $CSVData = $NoComputer | ConvertTo-Csv -NoTypeInformation
       $CSVData | Select-Object -Skip 1 |
       Export-Csv "File Path" -NoTypeInformation -Append #<-- Error happens on this line, according to host
    }
}

当运行如上所示的脚本时,它仍然向主机抛出错误消息,以及每个缺失系统的两列,如下所示(出于隐私原因未显示实际计算机名称):

Name                           Value                                                                                                                                                          
----                           -----                                                                                                                                                          
Name                           ComputerName                                                                                                                  
CanonicalName                                                                                                                                            
Division                       Object Not Found

它还会在主机中抛出以下错误消息:

Export-Csv : Cannot append CSV content to the following file: File Path\Computer 
Identity List.csv. The appended object does not have a property that corresponds to the following column: Name. To continue with mismatched properties, add the -Force parameter, and then 
retry the command.
At File Path.ps1:36 char:8
+        Export-Csv File Path
+        ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    + CategoryInfo          : InvalidData: (Name:String) [Export-Csv], InvalidOperationException
    + FullyQualifiedErrorId : CannotAppendCsvWithMismatchedPropertyNames,Microsoft.PowerShell.Commands.ExportCsvCommand

然后,当我希望它列出系统并附加它在 CSV 文件的“分区”列中找不到带有“未找到对象”的系统时,它会在 CSV 文件中忽略该系统。我尝试执行 -Force,但它只是创建一个空白行。根据我查到的内容,这应该有效,但显然我错过了一些东西。为了使这项工作正常进行,我需要改变什么?

powershell
  • 1 个回答
  • 33 Views

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    重新格式化数字,在固定位置插入分隔符

    • 6 个回答
  • Marko Smith

    为什么 C++20 概念会导致循环约束错误,而老式的 SFINAE 不会?

    • 2 个回答
  • Marko Smith

    VScode 自动卸载扩展的问题(Material 主题)

    • 2 个回答
  • Marko Smith

    Vue 3:创建时出错“预期标识符但发现‘导入’”[重复]

    • 1 个回答
  • Marko Smith

    具有指定基础类型但没有枚举器的“枚举类”的用途是什么?

    • 1 个回答
  • Marko Smith

    如何修复未手动导入的模块的 MODULE_NOT_FOUND 错误?

    • 6 个回答
  • Marko Smith

    `(表达式,左值) = 右值` 在 C 或 C++ 中是有效的赋值吗?为什么有些编译器会接受/拒绝它?

    • 3 个回答
  • Marko Smith

    在 C++ 中,一个不执行任何操作的空程序需要 204KB 的堆,但在 C 中则不需要

    • 1 个回答
  • Marko Smith

    PowerBI 目前与 BigQuery 不兼容:Simba 驱动程序与 Windows 更新有关

    • 2 个回答
  • Marko Smith

    AdMob:MobileAds.initialize() - 对于某些设备,“java.lang.Integer 无法转换为 java.lang.String”

    • 1 个回答
  • Martin Hope
    Fantastic Mr Fox msvc std::vector 实现中仅不接受可复制类型 2025-04-23 06:40:49 +0800 CST
  • Martin Hope
    Howard Hinnant 使用 chrono 查找下一个工作日 2025-04-21 08:30:25 +0800 CST
  • Martin Hope
    Fedor 构造函数的成员初始化程序可以包含另一个成员的初始化吗? 2025-04-15 01:01:44 +0800 CST
  • Martin Hope
    Petr Filipský 为什么 C++20 概念会导致循环约束错误,而老式的 SFINAE 不会? 2025-03-23 21:39:40 +0800 CST
  • Martin Hope
    Catskul C++20 是否进行了更改,允许从已知绑定数组“type(&)[N]”转换为未知绑定数组“type(&)[]”? 2025-03-04 06:57:53 +0800 CST
  • Martin Hope
    Stefan Pochmann 为什么 {2,3,10} 和 {x,3,10} (x=2) 的顺序不同? 2025-01-13 23:24:07 +0800 CST
  • Martin Hope
    Chad Feller 在 5.2 版中,bash 条件语句中的 [[ .. ]] 中的分号现在是可选的吗? 2024-10-21 05:50:33 +0800 CST
  • Martin Hope
    Wrench 为什么双破折号 (--) 会导致此 MariaDB 子句评估为 true? 2024-05-05 13:37:20 +0800 CST
  • Martin Hope
    Waket Zheng 为什么 `dict(id=1, **{'id': 2})` 有时会引发 `KeyError: 'id'` 而不是 TypeError? 2024-05-04 14:19:19 +0800 CST
  • Martin Hope
    user924 AdMob:MobileAds.initialize() - 对于某些设备,“java.lang.Integer 无法转换为 java.lang.String” 2024-03-20 03:12:31 +0800 CST

热门标签

python javascript c++ c# java typescript sql reactjs html

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve