このページの本文へ

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
【整備済み品】 富士通 ノートパソコン LIFEBOOK MU937 超軽量 薄型ノートPC■Win11搭載 / MS Office H&B 2019 / FHD(1920x1080)/第七世代 Celeron/8GBメモリ/SSD 256GB/Webカメラ内蔵/13.3インチ
【整備済み品】 富士通 ノートパソコン LIFEBOOK MU937 超軽量 薄型ノートPC■Win11搭載 / MS Office H&B 2019 / FHD(1920x1080)/第七世代 Celeron/8GBメモリ/SSD 256GB/Webカメラ内蔵/13.3インチ
¥19,800
2
Lenovo ノートパソコン パソコン IdeaPad Slim 3 14.0インチ 第13世代 インテル® Core™ i5 プロセッサー搭載 13420H メモリ16GB SSD512GB MS Office 2024搭載 Windows11 バッテリー駆動14.1時間 重量1.39kg ルナグレー 83K00072JP ノートPC
Lenovo ノートパソコン パソコン IdeaPad Slim 3 14.0インチ 第13世代 インテル® Core™ i5 プロセッサー搭載 13420H メモリ16GB SSD512GB MS Office 2024搭載 Windows11 バッテリー駆動14.1時間 重量1.39kg ルナグレー 83K00072JP ノートPC
¥107,800
3
【整備済み品】中古 ノートパソコン NEC VersaPro VKT16/15.6型・第8世代Core i5-8250U(最大動作3.4GHz)/快適メモリ8GB/ 高速SSD 256GB/Win11 Pro/MS Office 2019付属/テンキー付, Webカメラ, USB3.0, HDMI, VGA, 有線LAN, WIFI内蔵, Bluetooth/ACアダプター付属/180日間保証
【整備済み品】中古 ノートパソコン NEC VersaPro VKT16/15.6型・第8世代Core i5-8250U(最大動作3.4GHz)/快適メモリ8GB/ 高速SSD 256GB/Win11 Pro/MS Office 2019付属/テンキー付, Webカメラ, USB3.0, HDMI, VGA, 有線LAN, WIFI内蔵, Bluetooth/ACアダプター付属/180日間保証
¥26,880
4
【Amazon.co.jp限定】 HP ノートパソコン 15-fd 15.6インチ インテル Core i5-1334U メモリ16GB SSD512GB Windows 11 Microsoft Office 2024搭載 カメラシャッター 指紋認証 薄型 Copilotキー搭載 ナチュラルシルバー (BJ0M4PA-AAAB)
【Amazon.co.jp限定】 HP ノートパソコン 15-fd 15.6インチ インテル Core i5-1334U メモリ16GB SSD512GB Windows 11 Microsoft Office 2024搭載 カメラシャッター 指紋認証 薄型 Copilotキー搭載 ナチュラルシルバー (BJ0M4PA-AAAB)
¥181,469
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,979

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
¥1,880
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
【Amazon.co.jp限定】バッファロー microSD 32GB 100MB/s UHS-1 U1 microSDHC【 Nintendo Switch 対応 】V10 A1 IPX7 Full HD RMSD-032U11HA/N
【Amazon.co.jp限定】バッファロー microSD 32GB 100MB/s UHS-1 U1 microSDHC【 Nintendo Switch 対応 】V10 A1 IPX7 Full HD RMSD-032U11HA/N
¥980
4
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
5
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
6
KIOXIA(キオクシア)【日本製】USBフラッシュメモリ 32GB USB2.0 国内サポート正規品 KLU202A032GL
KIOXIA(キオクシア)【日本製】USBフラッシュメモリ 32GB USB2.0 国内サポート正規品 KLU202A032GL
¥980
7
【Amazon.co.jp限定】 ロジクール 静音 ワイヤレス トラックボール マウス M575SPd Bluetooth Logibolt 無線 windows mac iPad OS Chrome トラックボールマウス ブラック M575 M575SP 国内正規品 ※Amazon.co.jp限定 壁紙ダウンロード付き
【Amazon.co.jp限定】 ロジクール 静音 ワイヤレス トラックボール マウス M575SPd Bluetooth Logibolt 無線 windows mac iPad OS Chrome トラックボールマウス ブラック M575 M575SP 国内正規品 ※Amazon.co.jp限定 壁紙ダウンロード付き
¥5,280
8
キヤノン Canon 純正 インクカートリッジ BCI-381(BK/C/M/Y)+380 5色マルチパック BCI-381+380/5MP 長さ:5.3cm 幅:13.9cm 高さ:10.75cm
キヤノン Canon 純正 インクカートリッジ BCI-381(BK/C/M/Y)+380 5色マルチパック BCI-381+380/5MP 長さ:5.3cm 幅:13.9cm 高さ:10.75cm
¥5,545
9
バッファロー SDカード 128GB 100MB/s UHS-1 スピードクラス1 VideoSpeedClass10 IPX7 Full HD データ復旧サービス対応 RSDC-128U11HA/N
バッファロー SDカード 128GB 100MB/s UHS-1 スピードクラス1 VideoSpeedClass10 IPX7 Full HD データ復旧サービス対応 RSDC-128U11HA/N
¥1,980
10
バッファロー マウス 無線 ワイヤレス 5ボタン 【戻る/進むボタン搭載】 小型 軽量 節電モデル 最大584日使用可能 BlueLED ブラック BSMBW315BK
バッファロー マウス 無線 ワイヤレス 5ボタン 【戻る/進むボタン搭載】 小型 軽量 節電モデル 最大584日使用可能 BlueLED ブラック BSMBW315BK
¥1,040

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

デジタル用語辞典

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