1

Я хочу отобразить всю подключенную модель дисковода, имя, индекс и размер в командной строке. Я использую приведенный ниже простой код

    wmic diskdrive GET index,caption,name,size /format:table

Выход

Caption                   Index  Name                Size
SAMSUNG SSD PM830 2.5" 7  0      \\.\PHYSICALDRIVE0  256052966400
Seagate backup plus       1      \\.\PHYSICALDRIVE1  536870912000

Я хочу такой же вывод, как указано выше, за исключением того, что я хочу, чтобы размер отображался в ГБ

Я думаю, что есть какой-то способ сделать это, используя для циклов и временных файлов VB.

Я специально ищу Windows CMD код. Кто-нибудь может помочь?

Я могу сделать преобразование размера и отобразить его на cmd

    for /f "tokens=1,2" %a in ('WMIC DISKDRIVE GET Name^,Size ^|FINDSTR /I /V "Name"') do @echo wsh.echo "%a" ^& " size=" ^& FormatNumber^(cdbl^(%b^)/1024/1024/1024, 2^)^& " GiB" > %temp%\tmp.vbs & @if not "%b"=="" @echo( & @cscript //nologo %temp%\tmp.vbs & del %temp%\tmp.vbs

Выход

\\.\PHYSICALDRIVE0 Size=238.47 (GB)

Но я все еще не могу правильно отобразить название модели .. Я просто не могу заставить цикл for работать так, как задумано (в моем случае в имени модели есть пробелы между ними. Приведенный ниже код работает только для печати моделей).

    for /f "tokens=1-5 skip=1" %a in ('wmic diskdrive GET model') do @echo. %a %b %c %d %e

Выход

SAMSUNG SSD PM830 2.5" 7

Может ли кто-нибудь помочь мне объединить оба кода так, чтобы он отображал как

SAMSUNG SSD PM830 2.5" 7  \\.\PHYSICALDRIVE0  Size=238.47 (GB)

1 ответ1

0

Вычисления в cmd с set /A ограничены 32-битными числами со знаком, поэтому для выполнения математических операций вам понадобится vbscript или PowerShell. Вместо использования пакетных, wmic и vbscript у меня есть гибридный пакетный /vbscript файл, который устраняет необходимость создания временных файлов. Недостатком является повторяющийся rem & который необходим для того, чтобы обе версии скрипта принимали файл.

Сохраните это как файл .cmd/.bat

rem^ &@cls&cscript //nologo //e:vbscript "%~f0"&Pause&exit /b
On Error Resume Next
sComputer = "."
Set oWMI = GetObject("winmgmts:\\" & sComputer & "\root\cimv2")
Set cItems = oWMI.ExecQuery("Select * from Win32_DiskDrive",,48)
sOut = ""
For Each oItem in cItems
  sOut = sOut & JL(26,oItem.Model) & JL(20,oItem.Name) & "Size=" & _
  JR(8,FormatNumber(cdbl(oItem.Size)/1024/1024/1024, 2)) & " (GiB)" &vbCRLF
Next
Set cItems = Nothing

wscript.echo sOut

Function JL(Places, Value) ' Justify Left within Places
  If len (Value) < Places then
    JL=Left(Value & Space(Places), Places)
  Else
    JL=Value
   End If
end Function 
Function JR(Places, Value) ' Justify Right within Places
  If Len (Value) < Places then
    JR = Right(Space(Places) & Value, Places)
  Else
    JR=Value
   End If
end Function 

Вывод на мою систему (немецкий язык)

Hitachi HDS722020ALA330   \\.\PHYSICALDRIVE2  Size=1.863,01 (GiB)
VB0250EAVER               \\.\PHYSICALDRIVE0  Size=  232,88 (GiB)
ST2000DL003-9VT166        \\.\PHYSICALDRIVE1  Size=1.863,01 (GiB)

Drücken Sie eine beliebige Taste . . .

Всё ещё ищете ответ? Посмотрите другие вопросы с метками .