WMI Fun !! 〜 WMIに興味がある方・システム管理者必見!! 〜
 WMI Step|WMI Sample|WMI Reference|WMI Library|My Let'snote|Personal|Link|About WMI Fun !!

WMI Fun !! > WMI Sample (VBS) > コンピュータの種類を取得する

Panasonic Let'snoteを長年愛用しています、その理由はMy Let'snoteで…
インクを買うよりもしかしたら安い?インクジェット複合機HP Photosmart 5510
白いご飯や日本酒にもとても合うにしんのきりこみがマイブームです

コンピュータの種類を取得する: Win32_SystemEnclosure - WMI Sample (VBS)

Topics

コンピュータの種類(ノートとかデスクトップとか)を取得するサンプルプログラムです。Win32_SystemEnclosureクラスを使用します。

従来のVB(VB6)版のサンプルコードはこちらで公開しています。


Sample Code

Option Explicit

'WMIにて使用する各種オブジェクトを定義・生成する。
Dim oClassSet
Dim oClass
Dim oLocator
Dim oService
Dim sMesStr
Dim i

'ローカルコンピュータに接続する。
Set oLocator = Wscript.CreateObject("WbemScripting.SWbemLocator")
Set oService = oLocator.ConnectServer
'クエリー条件をWQLにて指定する。
Set oClassSet = oService.ExecQuery("Select * From Win32_SystemEnclosure")

'コレクションを解析する。
For Each oClass In oClassSet

For i = Lbound(oClass.ChassisTypes) To Ubound(oClass.ChassisTypes)

Select Case oClass.ChassisTypes(i)

Case 1:
sMesStr = sMesStr & "Other" & vbCrLf
Case 2:
sMesStr = sMesStr & "Unknown" & vbCrLf
Case 3:
sMesStr = sMesStr & "Desktop" & vbCrLf
Case 4:
sMesStr = sMesStr & "Low Profile Desktop" & vbCrLf
Case 5:
sMesStr = sMesStr & "Pizza Box" & vbCrLf
Case 6:
sMesStr = sMesStr & "Mini Tower" & vbCrLf
Case 7:
sMesStr = sMesStr & "Tower" & vbCrLf
Case 8:
sMesStr = sMesStr & "Portable" & vbCrLf
Case 9:
sMesStr = sMesStr & "Laptop" & vbCrLf
Case 10:
sMesStr = sMesStr & "Notebook" & vbCrLf
Case 11:
sMesStr = sMesStr & "Hand Held" & vbCrLf
Case 12:
sMesStr = sMesStr & "Docking Station" & vbCrLf
Case 13:
sMesStr = sMesStr & "All in One" & vbCrLf
Case 14:
sMesStr = sMesStr & "Sub Notebook" & vbCrLf
Case 15:
sMesStr = sMesStr & "Space -Saving" & vbCrLf
Case 16:
sMesStr = sMesStr & "Lunch Box" & vbCrLf
Case 17:
sMesStr = sMesStr & "Main System Chassis" & vbCrLf
Case 18:
sMesStr = sMesStr & "Expansion Chassis" & vbCrLf
Case 19:
sMesStr = sMesStr & "SubChassis" & vbCrLf
Case 20:
sMesStr = sMesStr & "Bus Expansion Chassis" & vbCrLf
Case 21:
sMesStr = sMesStr & "Peripheral Chassis" & vbCrLf
Case 22:
sMesStr = sMesStr & "Storage Chassis" & vbCrLf
Case 23:
sMesStr = sMesStr & "Rack Mount Chassis" & vbCrLf
Case 24:
sMesStr = sMesStr & "Sealed-Case PC" & vbCrLf

End Select

Next

Next

MsgBox "コンピュータの種類は、" & vbCrLf & vbCrLf & sMesStr & vbCrLf & "です。"


'使用した各種オブジェクトを後片付けする。
Set oClassSet = Nothing
Set oClass = Nothing
Set oService = Nothing
Set oLocator = Nothing


Comment

実際実行するとコンピュータがどんな種類なのか表示されます。 ChassisTypesプロパティは配列になっているため一応対応した形に記述してありますが今まで実行した限り値は一つしか入らないようです。ちなみに私自身で試したマシンの結果を書いておきます。

・Panasonic CF-B5ER : 14
・COMPAQ DeskPro EC 650 : 3
・DELL PowerEdge 1300: 6

他にもこんなマシンではこういう値が帰ってきたよという結果を教えていただければここにどんどん記述して行こうと思います。

Win32_SystemEnclosure クラスに関連するサンプルコードは他に、

を紹介しています。
なおWMIの使い方(VB6, VBS, VBA, VB.NET, VC#, PowerShellを対象)に関してはWMI Stepも参考にしてみてください。(WMI初心者・入門編としてもおすすめです。) 各種言語を使用したWMIを使用するたたき台としてソースコードテンプレートも公開しています。WMIプログラム/スクリプト作成時に役立てば…と思っています。


Recommended book

個人的にお勧めする本の紹介です。


Latest sample information

最近WMI Sampleへ追加したサンプルのご紹介です。

興味のあるサンプル・クラスがありましたら参考にしてみて下さい。


ご意見・ご要望・ご感想をこちらのアンケートからお待ちしています
WMIに関して調べているけど探し物が見つからない…という方はSearch Resultから検索してみましょう!!

MCP(Microsoft Certified Professional)一応MCP(Microsoft Certified Professional)、MCA(Microsoft Certified Associate)所有してたりします…

- WMI Fun !! -
http://www.wmifun.net/
Microsoft社のテクノロジーであるWMI(Windows Management Instrumentation)の使い方を
Visual Basicを使ってのんびり公開しています
WMIはVB/VBAや.Net(VB,C#)以外でもWMICやWSH(VBS,JS)・PowerShellなどスクリプト言語からも使えますよ!
Windowsベースの社内ITシステムに関する資産管理、アセットマネジメントや監視業務の効率化、 インベントリ情報収集系システムツール開発にWMIはお勧めです

This website is created by Toh.
Copyright(C) 1997-2012 WMI Fun !!. All rights reserved.
WMI Fun !!へのリンクはご自由に…相互リンクに関するお問い合わせはアンケートページからお願いします。

∧ ページの先頭へ…