このページの本文へ

Windows Info 第492回

PowerShellで列挙値を使う

2025年08月03日 10時00分更新

文● 塩田紳二 編集● ASCII

  • この記事をはてなブックマークに追加
  • 本文印刷

 Windowsに限らず、多くのOS/プラットフォームで、ビットパターンやフラグと呼ばれるデータ形式が使われている。簡単に言えば、これらは数値の2進数表現で各桁を使って「オン/オフ」「有効/無効」「あり/なし」という情報を扱う。

 大抵の言語には、こうしたフラグ/ビットパターンを扱う機能がある。一般に、フラグ/ビットパターンを扱うには、enumeration type(enumerated type)を使う。日本語では、列挙体や列挙型などと呼ぶ。言語中では、略して「emum」と表記されることが少なくない。

 .NETにも「列挙型」があるため、PowerShellでもこれを利用できる。PowerShell内でも「enum」キーワードを使う。まずは、列挙値をビットパターンして作ってみる。

[Flags()] enum BitPattern {bit0 = 1;bit1 = 2;bit2 = 4;bit3 = 8}

Windows

列挙型をフラグ形式として定義すると、数値をフラグに分解して1のフラグのみを列挙してくれる

 これで4ビットのフラグができた。構造体の名前を使う(キャストする)ことで、4ビットの数値(0~16)からオンになっているビットを調べることができる。

[BitPattern] 10

 「10」を2進数として表示するには、

[Convert]::ToString(10,2)

とする。

実際に使われているシステムのフラグを解析する

 さて、これからが本番である。実際にWindowsで使われているenum値を定義して、フラグのオンオフ状態を表示させてみる。コマンドについては、過去記事(「WindowsのPowerShellからBluetoothデバイスを調べる」)で扱っている。

 Bluetoothのステレオヘッドホンをペアリングしたのち、デバイスのオンオフで何が変わるかを調べてみる。

$myHeadPhone=(Get-PnpDevice | ? Class -eq "Bluetooth" | ? FriendlyName -eq 'MDR-ZX750BN').InstanceId
# デバイス未接続でプロパティを取得
$DevOff=Get-PnpDeviceProperty -InstanceId $myHeadPhone
# デバイス接続後にプロパティを取得
$DevOn=Get-PnpDeviceProperty -InstanceId $myHeadPhone
# $x1と$x2を比較
Compare-Object $DevOn $DevOff -Property KeyName,data | sort keyname

Windows

デバイスからBluetoothで特定のヘッドホン名を持つものを選び、接続前/接続後にプロパティを取得、Compare-Objectを使って差分を得る

 この比較だと、接続前と後で「{83DA6326-97A6-4088-9453-A1923F573B29} 15」と「DEVPKEY_Device_DevNodeStatus」が変化している。前者はFalseとTrueなので調べる必要もない。問題は「DEVPKEY_Device_DevNodeStatus」である。

 DEVPKEY_Device_DevNodeStatusをインターネット検索すると、Microsoftのページ(https://learn.microsoft.com/ja-jp/windows-hardware/drivers/install/devpkey-device-devnodestatus)が見つかる。ここには、「DEVPKEY_Device_DevNodeStatus の値は、Cfg.h で定義されている DN_Xxx ビットフラグのビットごとの OR です。」とある。Cfg.hは、WindowsのSDKに含まれているC/C++インクルードファイルの1つ。ファイルを入手するには、Windows SDKをインストールする必要がある。すでにSDKがインストールされているとすれば、Cfg.hには、以下の画面のような定義がある。

Windows

DEVPKEY_Device_DevNodeStatusの値は、Windows SDKのCfg.hに定義されている名前がDN_で始まるフラグ値からできている

 この#define文を前述のenumステートメントに変換すれば、列挙型が定義でき、これを使うことで、対象数値でどのフラグがオンになっているのかを表示させることが可能になる。簡易には、エディタを使った手作業でするか、以下のようなコマンドの出力を使ってスクリプトファイルを作成する。

"[Flags()] enum DN_ {" >C:\temp\mysc.ps1
Get-Content "cfg.h"|sls "^#define DN_[^ ]*[^0]+0x"|%{[Void](($_ -split '/')[0] -match "(DN_[^ ]+)[^0]+(0x[\w]+)");Write-Output "$($matches.1)=$($matches.2)"} >> C:\temp\mysc.ps1
"}" >>C:\temp\mysc.ps1

Windows

Cfg.hからDN_で始まる名前を持つ#define文を抜き出し、PowerShellのenumステートメントの定義形式に変換してファイルに記録する

 こうして、「C:\temp\mysc.ps1」ができたので、これをドットソース「. c:\temp\mysc.ps1」コマンドで実行させる。

 列挙型DN_Xが定義されたかどうかは、列挙型のメソッド、たとえば、「[DN_X].BaseType」などを実行させてみるとわかる。

 では、DEVPKEY_Device_DevNodeStatusの値を見てみることにしよう。

[DN_X]58744842
[Convert]::ToString(58744842,2)
[DN_X]25190410
[Convert]::ToString(25190410,2)

Windows

作成したps1ファイルをドットソースコマンド「.」で読み込むとenumが定義される。これを使って、数値をフラグに分解できる

 違いはDN_NEEDS_LOCKINGの有無。未接続のときにDN_NEEDS_LOCKINGがオンになっている。cfg.hを見ると、DN_NEEDS_LOCKINGには、別名としてDN_DEVICE_DISCONNECTEDが割り当ててあり、「The function driver for a device reported that the device is not connected.」という注釈があり、デバイスが未接続であることを表しているようだ。

 Bluetoothデバイスが接続中かどうかは、DEVPKEY_Device_DevNodeStatusの値にDN_NEEDS_LOCKINGがあるかどうかを判定すればよいことがわかる。

 enumを使わないと、数値の中でどのフラグが1になっているのかをPowerShellで調べるにはプログラムを書かねばならない。2進数表示させたとしても、1のビットの桁位置を調べるのは面倒だ。列挙型を定義できるなら、これを使ってどのフラグがオンなのかを簡単に調べることが可能だ。

カテゴリートップへ

この連載の記事
1
Apple 2026 MacBook Air M5チップ搭載13インチノートブック:AIとApple Intelligence、13.6インチLiquid Retinaディスプレイ、16GBユニファイドメモリ、512GB SSDストレージ、12MPセンターフレームカメラ、Touch ID - スカイブルー
Apple 2026 MacBook Air M5チップ搭載13インチノートブック:AIとApple Intelligence、13.6インチLiquid Retinaディスプレイ、16GBユニファイドメモリ、512GB SSDストレージ、12MPセンターフレームカメラ、Touch ID - スカイブルー
¥177,333
2
Apple 2026 MacBook Neo A18 Proチップ搭載13インチノートブック:AIとApple Intelligenceのために設計、Liquid Retinaディスプレイ、8GBユニファイドメモリ、512GB SSDストレージ、1080p FaceTime HDカメラ、Touch ID - シトラス
Apple 2026 MacBook Neo A18 Proチップ搭載13インチノートブック:AIとApple Intelligenceのために設計、Liquid Retinaディスプレイ、8GBユニファイドメモリ、512GB SSDストレージ、1080p FaceTime HDカメラ、Touch ID - シトラス
¥110,162
3
Lenovo Chromebook クロームブック IdeaPad Flex 3i Gen8 12.2インチ インテル® プロセッサー N100搭載 メモリ4GB eMMC 64GB バッテリー駆動12.0時間 重量1.25kg アビスブルー 82XH001KJP
Lenovo Chromebook クロームブック IdeaPad Flex 3i Gen8 12.2インチ インテル® プロセッサー N100搭載 メモリ4GB eMMC 64GB バッテリー駆動12.0時間 重量1.25kg アビスブルー 82XH001KJP
¥39,255
4
ASUS Chromebook クロームブック Detachable CM30 10.5インチ 2in1 タブレット 日本語キーボード 8GBメモリ 重量609g ペン付き フォグシルバー CM3001DM2A-R70006/A
ASUS Chromebook クロームブック Detachable CM30 10.5インチ 2in1 タブレット 日本語キーボード 8GBメモリ 重量609g ペン付き フォグシルバー CM3001DM2A-R70006/A
¥44,800
5
【整備済み品】富士通 ノートパソコン LIFEBOOK U9310 13.3型FHD(1920x1080) 超軽薄 ノートPC/第10世代 Core i5-10310U@1.7GHz/ 8GB メモリ/高速ストレージ SSD/Webカメラ/WIFI/Type-C/HDMI/win11&MS Office 2019 搭載 ビジネス 在宅勤務向け パソコン (メモリ:8GB/SSD:256GB)
【整備済み品】富士通 ノートパソコン LIFEBOOK U9310 13.3型FHD(1920x1080) 超軽薄 ノートPC/第10世代 Core i5-10310U@1.7GHz/ 8GB メモリ/高速ストレージ SSD/Webカメラ/WIFI/Type-C/HDMI/win11&MS Office 2019 搭載 ビジネス 在宅勤務向け パソコン (メモリ:8GB/SSD:256GB)
¥36,970

Amazonのアソシエイトとして、ASCII.jpは適格販売により収入を得ています。

ASCII倶楽部

注目ニュース

  • 角川アスキー総合研究所

プレミアム実機レビュー

ピックアップ
1
KIOXIA(キオクシア) 旧東芝メモリ microSD 128GB UHS-I Class10 (最大読出速度100MB/s) Nintendo Switch動作確認済 国内サポート正規品 メーカー保証5年 KLMEA128G
KIOXIA(キオクシア) 旧東芝メモリ microSD 128GB UHS-I Class10 (最大読出速度100MB/s) Nintendo Switch動作確認済 国内サポート正規品 メーカー保証5年 KLMEA128G
¥2,280
2
Anker PowerLine III Flow USB-C & USB-C ケーブル Anker絡まないケーブル 240W 結束バンド付き USB PD対応 シリコン素材採用 iPhone 17 / 16 / 15 / Galaxy iPad Pro MacBook Pro/Air 各種対応 (1.8m ミッドナイトブラック)
Anker PowerLine III Flow USB-C & USB-C ケーブル Anker絡まないケーブル 240W 結束バンド付き USB PD対応 シリコン素材採用 iPhone 17 / 16 / 15 / Galaxy iPad Pro MacBook Pro/Air 各種対応 (1.8m ミッドナイトブラック)
¥1,890
3
Anker USB Type C ケーブル PowerLine USB-C & USB-A 3.0 ケーブル iPhone 17 / 16 / 15 /Xperia/Galaxy/LG/iPad Pro/MacBook その他 Android 等 USB-C機器対応 テレワーク リモート 在宅勤務 0.9m ホワイト
Anker USB Type C ケーブル PowerLine USB-C & USB-A 3.0 ケーブル iPhone 17 / 16 / 15 /Xperia/Galaxy/LG/iPad Pro/MacBook その他 Android 等 USB-C機器対応 テレワーク リモート 在宅勤務 0.9m ホワイト
¥740
4
UGREEN USB Type Cケーブル PD対応 100W/5A 超急速充電 USB C ナイロン編み 断線防止 iphone17/16/15シリーズ/iPad/MacBook Pro/Galaxy S24/Matebook/iPad/Xperia等USB-C各種対応(1m, ブラック)
UGREEN USB Type Cケーブル PD対応 100W/5A 超急速充電 USB C ナイロン編み 断線防止 iphone17/16/15シリーズ/iPad/MacBook Pro/Galaxy S24/Matebook/iPad/Xperia等USB-C各種対応(1m, ブラック)
¥743
5
Anker iPhone充電ケーブル PowerLine II ライトニングケーブル MFi認証 超高耐久 iPhone 14 / 14 Pro Max / 14 Plus / 13 / 13 Pro / 12 / 11 / X/XS/XR / 8 Plus 各種対応 (0.9m ホワイト)
Anker iPhone充電ケーブル PowerLine II ライトニングケーブル MFi認証 超高耐久 iPhone 14 / 14 Pro Max / 14 Plus / 13 / 13 Pro / 12 / 11 / X/XS/XR / 8 Plus 各種対応 (0.9m ホワイト)
¥990
6
KIOXIA(キオクシア)【日本製】USBフラッシュメモリ 32GB USB2.0 国内サポート正規品 KLU202A032GW
KIOXIA(キオクシア)【日本製】USBフラッシュメモリ 32GB USB2.0 国内サポート正規品 KLU202A032GW
¥980
7
KIOXIA(キオクシア)【日本製】SDカード 64GB SDXC UHS-I Class10 読出速度100MB/s 国内正規品 メーカー保証5年 KLNEA064G
KIOXIA(キオクシア)【日本製】SDカード 64GB SDXC UHS-I Class10 読出速度100MB/s 国内正規品 メーカー保証5年 KLNEA064G
¥1,180
8
NIMASO ガラスフィルム iPad 第11世代(A16) 2025用/iPad 10.9インチ 第10世代 2022用 衝撃吸収 強化 ガラス 保護フィルム 指紋防止 ガイド枠付き NTB22I574
NIMASO ガラスフィルム iPad 第11世代(A16) 2025用/iPad 10.9インチ 第10世代 2022用 衝撃吸収 強化 ガラス 保護フィルム 指紋防止 ガイド枠付き NTB22I574
¥1,359
9
エルパ(ELPA) 扉付タップラン 電源タップ 延長コード 125V 3m 3個口 ホワイト WBT-N3030B(W)
エルパ(ELPA) 扉付タップラン 電源タップ 延長コード 125V 3m 3個口 ホワイト WBT-N3030B(W)
¥652
10
バッファロー マウス 無線 ワイヤレス 5ボタン 【戻る/進むボタン搭載】 小型 軽量 節電モデル 最大584日使用可能 BlueLED ブラック BSMBW315BK
バッファロー マウス 無線 ワイヤレス 5ボタン 【戻る/進むボタン搭載】 小型 軽量 節電モデル 最大584日使用可能 BlueLED ブラック BSMBW315BK
¥1,040

Amazonのアソシエイトとして、ASCII.jpは適格販売により収入を得ています。

デジタル用語辞典

ASCII.jpメール デジタルMac/iPodマガジン