PowerShellの今を見る 2つあるPowerShellはどっち使えばいい?
ASCII.jp / 2024年3月17日 10時0分
PowerShellに関しては、2021年に1回まとめたのだが、あれから3年も経過したので最新情報も含めて、簡単に解説したい。なお、それぞれのこれまでの経緯などは、過去記事に記載しているので参考にしてほしい。
●あらためて「PowerShell」の現状と登場後の経緯を整理する https://ascii.jp/elem/000/004/052/4052789/
結論から言えば、PowerShellには、Windowsに同梱されている「Windows PowerShell」と、ユーザーがインストールする必要がある「PowerShell」がある。コマンドラインを使う頻度が高いようならば、最新のPowerShellをインストール、そうでなければWindows PowerShellで十分である。
PowerShellのインストーラーなどに表示される奇妙な人物イラストを見たことがある人もいるだろう。これはPowerShellのマスコットらしい(PowerShell Digital Artにアメコミ調のコミックがあり、マーベルっぽいヒロインだ)。 。
![PowerShell](https://ascii.jp/img/2024/03/16/3703114/x/efd2c0d628af1907.jpg)
PowerShellの前提となる「.NET」とは?
PowerShellの解説をするには、まず「.NET」についての簡単な理解が必要になる。「.NET」とは、アプリケーションの開発、実行環境で、現在のWindowsソフトウェア開発の主流になっているものだ。
過去に作られたアプリケーションを含めれば、機械語のアプリケーションの方が多いと思われるが、現在も開発されているアプリケーションに着目すると、「.NET」の利用が多いと思われる。.NETについても過去にこれまでの経緯をまとめた。
●あらためて「.NET」について整理する https://ascii.jp/elem/000/004/051/4051022/
「.NET」には、「.NET Framework」と「.NET Core」(略して.NETと呼ぶ)の2種がある。.NET Frameworkが最初に作られ、Windows VistaからWindowsに同梱されてきた。
.NET Frameworkの最新版は、.NET Framework Ver.4.8.1で、Windows 11にも搭載されている。.NET Frameworkは、今後メジャーアップデートすることはなく、今後のWindowsにも4.8.xが同梱される。セキュリティ/バグフィックスのアップデートはあるが、最新機能への対応などは、後継とされる.NET Coreが担う。
.NET coreは、現在では単に.NETと呼ばれる。この記事では、.NETと.NET Frameworkを総称するときは、カッコ付きで「.NET」と表記している。.NETはオープンソースで開発され、現在では、毎年11月にアップデートされている。3年(36ヵ月)のサポート期間を持つLTSと、18ヵ月(1年半)のサポート期間のSTSを1年ごとに交互にリリースする。なお、リリースには、実行環境だけの「.NETランタイム」と、開発環境を含む「.NET SDK」の2つがある。
最新版の.NET 8(Ver.8.x)は、2023年11月に出荷され、LTSのため、2026年までサポートされる。原稿執筆時点では、.NET 7(Ver.7.x)が今年5月まで、.NET 6が今年11月までサポートされている。
このように最低でも複数の.NETバージョンが利用できるが、それぞれサポート期間があり、実行環境としては、継続的にアップデートしなければならない。ただし多くの場合、アプリケーションをインストールするときに、自動的にランタイムがインストールされるため、ユーザーは特に意識する必要はない。また、インストールされた.NETは、Windows Update経由でアップデートされる。
以下の表に.NET Frameworkと.NET Coreのこれまでのバージョン履歴を示す。
![PowerShell](https://ascii.jp/img/2024/03/16/3703115/x/bc6fed3640103810.png)
PowerShellと.NETの関係
PowerShellには、Windowsに同梱されている「Windows PowerShell」と、以前はPowerShell Coreと呼ばれていた「PowerShell(Core)」の2つがある。違いは、Windows PowerShellは、.NET Frameworkを使って開発されているのに対して、PowerShellは、.NET Coreを使って開発されていることにある。以下の表は、Windows PowerShellとPowerShellのバージョン履歴である。
![PowerShell](https://ascii.jp/img/2024/03/16/3703116/x/8ccb3f0aef395db7.png)
また、PowerShellは、以前には「PowerShell Core」と表記されていたが、2021年に.NET Coreが.NETになったタイミングで、PowerShellと表記されるようになった。また、2021年以前の古い記事では、Windows PowerShellをPowerShellと略記していることがあるので注意が必要だ。
「Windows PowerShell」とPowerShellの最大の違いは、対応している「.NET」の違いである。また、Windows PowerShellは、Windows Updateで更新される(必ず更新されるわけではない)。これに対して、PowerShellには、複数のインストール方法があり、更新方法もインストール方法ごとに異なる。
対応する「.NET」の違いは、PowerShellスクリプトの微妙な互換性に影響する。同じオブジェクトのメソッドでも、「.NET」のバージョンにより動作が異なる。特に.NET Frameworkと.NETでは、非互換性が生じることがある。
というのも、PowerShellでは、「.NET」のオブジェクトを利用し、そのプロパティやメソッドを自由に呼び出せるからだ。このとき、.NET Frameworkで作られたWindows PowerShellは、.NET Frameworkのオブジェクトを扱い、.NETで作られたPowerShellは、.NETのオブジェクトを扱う。このため、同じ文法、同じステートメントでも、呼び出される「.NET」に違いが生じる。
例えばPowerShellの文字列は、.NET Framework、.NETのSystem.Stringクラスのオブジェクトだ。.NET Frameworkと.NETのStringクラスには違いがあり、.NET 8ではメソッドなどが追加されている。たとえば、.NET FrameworkではSplitメソッドが6個(引数のパターンが異なる)しかないが、.NET 8には8個ある。これは、Microsoftのページに記述がある。
●.NET Frame 4.8.1 String クラス https://learn.microsoft.com/ja-jp/dotnet/api/system.string?view=netframework-4.8.1#methods ●.NET 8 String クラス https://learn.microsoft.com/ja-jp/dotnet/api/system.string?view=net-8.0#methods
PowerShellで利用できる文字列のSplit()メソッドは、PowerShellが「.NET」のメソッドを呼び出しているだけである。つまり、SplitメソッドはPowerShellではなく「.NET」の範疇にあり、その挙動はPowerShellの埒外にある。
このためスクリプトを書く場合に互換性を高めるには、できるだけPowerShellの文法内で記述する必要がある。たとえば、文字列の分割ならPowerShellの分割演算子「-split」を使う。ちなみに「-split」はRegexクラスのSplit()メソッドを使って実装されている。
PowerShellのインストール
PowerShellを今インストールするなら、最新版は.NET 8を使うVer.7.4となる。しかし、.NET 7を使うPowerShell Ver.7.3やその前のVer.7.2の方が、利用されている期間が長く、さまざまなバグが修正されていて“枯れている”といえる。大部分のソースコードは、前バージョンのものを使うため、新しいからといって枯れていないわけではないが、新規に追加・修正した部分があり、その部分の実績は新しいものほど短いものになる。
ただし、“枯れ”具合は、PowerShellをよほど使い込んでいないとわからないだろう。とはいえ、運が悪いとバグに行き当たることもある。どれにするかはご自分のリスクで判断していただきたい。なお、.NETが毎年11月にバージョンアップするため、PowerShellも毎年11月をメドにバージョンアップが行われる。
PowerShellは、winget、Microsoftストア、DotNetSDKからインストールが可能で、そのほかZIPファイル、MSIファイルをGitHub(https://github.com/PowerShell/PowerShell/releases)などからダウンロードして手動でインストールする方法がある。
![PowerShell](https://ascii.jp/img/2024/03/16/3703117/x/7c1ba3c7d9d2b92e.png)
このうち、推奨されるのは、winget経由でのインストールである。原則アップデートは、インストールと同じ方法でする必要があり、Wingetの場合、「ピン留め」機能で、バージョン固定やアップデート禁止などができるため制御がしやすい。
なお、Microsoftストアからのインストールは可能だがお勧めできない。Microsoftストアからインストールしたアプリは、原則インストール先フォルダへのアクセスが制限されるため、本格的な利用には向いていないのだ。
Wingetでは、インストールしたプログラムのアップデート(Upgrade)を制御する「ピン留め」がサポートされており、これを使って、特定のPowerShellを継続して使うことができる。ピン留めすることで、wingetのUpgradeサブコマンドの対象から除外される。詳しくは、過去記事(「Wingetにおける安定版v1.14からプレビュー版v1.16での新機能」)を参照してほしい。
また、PowerShellでは、安定版とプレビュー版は同時にインストールすることができる。
どのPowerShellを使うかは悩ましいところだが、システム管理などで複数のマシンで実行させるようなスクリプトを作らなければならない立場なら、インストール不要で仕様の安定しているWindows PowerShell上で開発し、余裕があればPowerShellでもスクリプトを検証しておくべきだろうか。
使い分けるのが面倒なら、選択は管理対象のマシンや実行環境とご相談といったところだが、まだWindows PowerShell一本槍でも構わないと思う。少なくとも緊急時にインストール不要でスクリプトを実行できる。利便性を取るか、安全性を取るかといったところか。
この記事に関連するニュース
-
Windowsはなぜ再起動が必要になるのか?
ASCII.jp / 2024年6月30日 10時0分
-
Windowsが今更(?)開発者に優しくなろうとしている!? 「Dev Home」は開発者にとって使い物になる?
ASCII.jp / 2024年6月23日 10時0分
-
Microsoft、Windows 10の右クリックバグに対処中
マイナビニュース / 2024年6月19日 18時43分
-
ユーザー自らマルウェアをインストール、偽の警告メッセージに注意
マイナビニュース / 2024年6月19日 8時26分
-
Windows Subsystem for Linuxガイド 第36回 WSL2でDockerを使う その2「Dockerエンジン編」
マイナビニュース / 2024年6月10日 17時57分
ランキング
-
1老後の趣味で気軽に“塗り絵”を始めて1年後…… めきめき上達した70代女性の美麗な水彩画に「本当にすごい…」「感動です」
ねとらぼ / 2024年6月29日 22時0分
-
2藤本美貴&庄司智春、真っ昼間に変装ゼロで“腕絡め”デート 大勢の注目浴びるも“モザイク9割”の結果で「笑った」
ねとらぼ / 2024年7月2日 15時1分
-
3中小企業の社内Wi-Fi接続、約半数が「つながりにくさ」を実感‐対処法は?
マイナビニュース / 2024年7月3日 11時50分
-
4新紙幣「一万円札と千円札の1の字が違う」SNSに違和感覚えるという声も…… 「1」のデザインが違う理由は?
ねとらぼ / 2024年7月3日 18時15分
-
5シャオミ、ペンを発売 「書き心地は良いが、タブレットとペアリングはできません」と公式
ITmedia NEWS / 2024年7月3日 8時30分
記事ミッション中・・・
記事にリアクションする
![](/pc/img/mission/mission_close_icon.png)
記事ミッション中・・・
記事にリアクションする
![](/pc/img/mission/point-loading.png)
エラーが発生しました
ページを再読み込みして
ください
![](/pc/img/mission/mission_close_icon.png)