Home Software Windows winget: Windows Package Manager 管理者としてではなく普通に実行したシェルではwingetコマンドが認識されないときの対処法 @wakairo 2023/02/10 17:51 最終更新 2023/02/11 23:11 現象 管理者として実行したコマンドプロンプトやPowerShellでは問題なくwingetを利用できる。 しかし、管理者として実行しなかったコマンドプロンプトやPowerShellではwingetが「認識されていません」などとなって実行できない。 原因 環境変数のPathに対応するレジストリの値の種類がREG_SZになっている。 原因がレジストリにあるか確認する方法 PowerShellで以下のコマンドを実行したときの結果を見て、 REG Query HKCU\Environment /V Path 以下のように、Pathの種類がREG_SZとなっている場合は、問題の原因はこのレジストリの設定です。 HKEY_CURRENT_USER\Environment Path REG_SZ C:\foobar;%USERPROFILE%\AppData\Local\Microsoft\WindowsApps 修正方法 このWebページに載っている以下のコマンドを実行します。 if ((gi HKCU:\Environment).GetValueKind("Path") -eq "String") {sp Registry::HKEY_CURRENT_USER\Environment Path (gi HKCU:\Environment).GetValue("Path",$null,"DoNotExpandEnvironmentNames") -Type ExpandString; [Environment]::SetEnvironmentVariable("WM_SETTINGCHANGE","","User")} 修正できたかの確認 PowerShellで、以下のように、先ほどと同じコマンドを実行し、Pathの種類がREG_EXPAND_SZに変わったことを確認します。 PS C:\Users\wakai> REG Query HKCU\Environment /V Path HKEY_CURRENT_USER\Environment Path REG_EXPAND_SZ C:\foobar;%USERPROFILE%\AppData\Local\Microsoft\WindowsApps さらに、管理者として実行していないPowerShellかコマンドプロンプトで以下のコマンドを実行し、バージョンが無事表示されるようになっていれば、修正が出来ています。 winget -v なお、レジストリを変更した後は、念のためコンピュータの再起動をしておいた方が良いかもしません。 謝辞 この問題の解決では、前述のkou1okadaさんのWebページの情報が大きな助けとなりました。この場を借りて御礼申し上げます。
Home Software Windows winget: Windows Package Manager wingetのエラー表示はWingetUIよりも不親切? @wakairo 2023/02/10 11:54 最終更新 2023/02/10 11:55 アプリケーションの更新が失敗したときやエラーが発生したときの表示がwingetは不親切な気がしています。 wingetでエラーなどが発生したときに、wingetが返したメッセージを読んでも、次にいったいどうすればいいのかよく分からないことが多いように感じています。 それに比べると、WingetUIはwingetよりも関連する情報を多めに出してくれるので、親切な気がします。 wingetでもやりようはあるのでしょうが、ライトユーザーが日常的なメンテナンスをする分には、WingetUIの方が適しているのかもしれません。
Home Software Windows UniGetUI (formerly WingetUI) UniGetUI(旧WingetUI)のインストール @wakairo 2023/02/10 11:42 最終更新 2024/10/26 15:12 公式のGitHubのREADMEにも書かれていますが、 インストールはPowerShellかコマンドプロンプトで以下のコマンドを実行することで簡単にできます。 winget install --exact --id MartiCliment.UniGetUI --source winget インストーラーをダウンロードして実行することでもインストールできるようですが、せっかくwingetがパッケージ管理をしてくれるのですから、wingetコマンドからのインストールの方が良さそうな気がします。 なお、2024年10月現在、前述のREADMEでは、Microsoft Storeからのインストールが推奨(recommended)となっています。winget以外のパッケージ・マネジャーも多数サポートするようになり、利用目的がwinget以外のパッケージ・マネジャーである方への配慮として、推奨をMicrosoft Storeにしたのかもしれません。推測ですが。
Home Software Windows winget: Windows Package Manager wingetを利用したアプリのアップデートの仕方 @wakairo 2023/02/10 11:28 ちなみに、初めてwinget upgrade --allを実行したときに、エラーが出たり、更新に失敗したりしたアプリケーションがそれなりにありました。 ただ、それらのアプリケーションを1つずつ確認してみると、サポート切れ等で不要となったアプリが大半でしたので、アンインストールすることで大半の問題は解決しました。 また、wingetでインストールしたアプリでない場合は、エラーに関連するものなど一通りをアンインストールした後で、wingetで改めてインストールするというのが有効な場合がありました。
Home Software Windows winget: Windows Package Manager wingetを利用したアプリのアップデートの仕方 @wakairo 2023/02/10 11:20 最終更新 2024/08/14 16:06 以下のコマンドで、更新が可能なアプリケーションの一覧が表示されます。 winget upgrade 表示された全てのアプリケーションを更新するには、以下のコマンドを実行します。 winget upgrade --all IDを指定して、特定のアプリケーションを更新するには、以下のコマンドを実行します。 winget upgrade --id Microsoft.PowerToys 参考 Microsoft Learn: upgrade コマンド (winget)
Home Software Windows winget: Windows Package Manager wingetがインストールされているかの確認方法(wingetは、管理者として実行したシェルでないと実行できないことがある) @wakairo 2023/02/10 10:54 管理者として実行したシェルでないとwingetが実行できないという症状について、マイクロソフト コミュニティで質問してみました。 https://answers.microsoft.com/ja-jp/windows/forum/windows_10-performance/%e7%ae%a1%e7%90%86%e8%80%85%e3%81%a8%e3%81%97/63903580-72f9-4090-95c0-fc2870029fdb
Home Software Windows winget: Windows Package Manager wingetがインストールされているかの確認方法(wingetは、管理者として実行したシェルでないと実行できないことがある) @wakairo 2023/02/09 18:24 最終更新 2023/02/09 18:25 ちなみにWindows 10で、管理者として実行したシェルでないとwingetが実行できないという症状を直して、管理者としてではなく普通に実行したシェルでもwingetを実行できるようにするにはどうすればいいかをご存じの方は、教えていただけると嬉しいです。 Microsoft Storeからインストールされたwingetが「アプリ実行エイリアス」によってシェルから実行できるようになっていることまでは分かったのですが、管理者権限の有無によってシェルから実行できたりできなかったりするという違いが発生する理由は分かりませんでした。
Home Software Windows winget: Windows Package Manager wingetがインストールされているかの確認方法(wingetは、管理者として実行したシェルでないと実行できないことがある) @wakairo 2023/02/09 17:27 最終更新 2023/02/10 18:37 Windows 10とWindows 11では、わざわざインストール作業をしなくてもwingetがすでに入っていることが多いです。 自分のWindows環境にwingetが入っているか確認する際は、管理者としてPowerShellかコマンドプロンプトを立ち上げて、以下のコマンドでバージョンが表示されるかどうかで確認することがおすすめです。 winget -v なぜ管理者でのシェルの実行をおすすめするかというと、Windows 10 Pro 22H2で、管理者としてではなく普通に実行したシェルではwingetコマンドが認識されず実行できないことがあったからです。(この問題の修正方法はこちら) ちなみに、wingetがインストールされているかを確認する他の方法としては、以下の2つもあります。 ウインドウズキーを押してスタートメニューを開いた直後に「winget」とキーボードから打ち込む。コマンドの検索結果としてwingetがあれば、wingetはインストール済みのはず。 Microsoft Storeで「アプリ インストーラー」を検索し、「インストール済み」となっていれば、wingetはインストール済みのはず。
Home Software Unix その他 GNU Emacs 全選択はC-x hか、もしくは、メニューから @wakairo 2023/02/09 11:50 emacsで全選択するにはC-x h。 emacsでは全選択はときどきしかしないため、このキーバインドはなかなか覚えないなと思っていたら、 メニューバーを使うやり方の記事を見つけました。 確かにメニューバーに覚えておいてもらうのも1つの手だなと思いました。
Home Software Unix その他 GNU Emacs タブを区別して表示する @wakairo 2023/02/09 11:04 ちなみに、タブが混入していたときに、一括して空白に置き換えるにはM-x untabify。 emacsで見ると綺麗にインデントされているが実は空白とタブがグチャグチャになっているようなファイルを空白に統一するときにとても便利です。 参考 https://flex.phys.tohoku.ac.jp/texi/emacs-jp/emacs-jp_104.html
管理者としてではなく普通に実行したシェルではwingetコマンドが認識されないときの対処法
現象
管理者として実行したコマンドプロンプトやPowerShellでは問題なくwingetを利用できる。 しかし、管理者として実行しなかったコマンドプロンプトやPowerShellではwingetが「認識されていません」などとなって実行できない。
原因
環境変数のPathに対応するレジストリの値の種類がREG_SZになっている。
原因がレジストリにあるか確認する方法
PowerShellで以下のコマンドを実行したときの結果を見て、
以下のように、Pathの種類がREG_SZとなっている場合は、問題の原因はこのレジストリの設定です。
修正方法
このWebページに載っている以下のコマンドを実行します。
修正できたかの確認
PowerShellで、以下のように、先ほどと同じコマンドを実行し、Pathの種類がREG_EXPAND_SZに変わったことを確認します。
さらに、管理者として実行していないPowerShellかコマンドプロンプトで以下のコマンドを実行し、バージョンが無事表示されるようになっていれば、修正が出来ています。
なお、レジストリを変更した後は、念のためコンピュータの再起動をしておいた方が良いかもしません。
謝辞
この問題の解決では、前述のkou1okadaさんのWebページの情報が大きな助けとなりました。この場を借りて御礼申し上げます。
wingetのエラー表示はWingetUIよりも不親切?
アプリケーションの更新が失敗したときやエラーが発生したときの表示がwingetは不親切な気がしています。
wingetでエラーなどが発生したときに、wingetが返したメッセージを読んでも、次にいったいどうすればいいのかよく分からないことが多いように感じています。
それに比べると、WingetUIはwingetよりも関連する情報を多めに出してくれるので、親切な気がします。
wingetでもやりようはあるのでしょうが、ライトユーザーが日常的なメンテナンスをする分には、WingetUIの方が適しているのかもしれません。
UniGetUI(旧WingetUI)のインストール
公式のGitHubのREADMEにも書かれていますが、
インストールはPowerShellかコマンドプロンプトで以下のコマンドを実行することで簡単にできます。
インストーラーをダウンロードして実行することでもインストールできるようですが、せっかくwingetがパッケージ管理をしてくれるのですから、wingetコマンドからのインストールの方が良さそうな気がします。
なお、2024年10月現在、前述のREADMEでは、Microsoft Storeからのインストールが推奨(recommended)となっています。winget以外のパッケージ・マネジャーも多数サポートするようになり、利用目的がwinget以外のパッケージ・マネジャーである方への配慮として、推奨をMicrosoft Storeにしたのかもしれません。推測ですが。
wingetを利用したアプリのアップデートの仕方
ちなみに、初めて
winget upgrade --all
を実行したときに、エラーが出たり、更新に失敗したりしたアプリケーションがそれなりにありました。ただ、それらのアプリケーションを1つずつ確認してみると、サポート切れ等で不要となったアプリが大半でしたので、アンインストールすることで大半の問題は解決しました。
また、wingetでインストールしたアプリでない場合は、エラーに関連するものなど一通りをアンインストールした後で、wingetで改めてインストールするというのが有効な場合がありました。
wingetを利用したアプリのアップデートの仕方
以下のコマンドで、更新が可能なアプリケーションの一覧が表示されます。
表示された全てのアプリケーションを更新するには、以下のコマンドを実行します。
IDを指定して、特定のアプリケーションを更新するには、以下のコマンドを実行します。
参考
Microsoft Learn: upgrade コマンド (winget)
wingetがインストールされているかの確認方法(wingetは、管理者として実行したシェルでないと実行できないことがある)
管理者として実行したシェルでないとwingetが実行できないという症状について、マイクロソフト コミュニティで質問してみました。
https://answers.microsoft.com/ja-jp/windows/forum/windows_10-performance/%e7%ae%a1%e7%90%86%e8%80%85%e3%81%a8%e3%81%97/63903580-72f9-4090-95c0-fc2870029fdb
wingetがインストールされているかの確認方法(wingetは、管理者として実行したシェルでないと実行できないことがある)
ちなみにWindows 10で、管理者として実行したシェルでないとwingetが実行できないという症状を直して、管理者としてではなく普通に実行したシェルでもwingetを実行できるようにするにはどうすればいいかをご存じの方は、教えていただけると嬉しいです。
Microsoft Storeからインストールされたwingetが「アプリ実行エイリアス」によってシェルから実行できるようになっていることまでは分かったのですが、管理者権限の有無によってシェルから実行できたりできなかったりするという違いが発生する理由は分かりませんでした。
wingetがインストールされているかの確認方法(wingetは、管理者として実行したシェルでないと実行できないことがある)
Windows 10とWindows 11では、わざわざインストール作業をしなくてもwingetがすでに入っていることが多いです。
自分のWindows環境にwingetが入っているか確認する際は、管理者としてPowerShellかコマンドプロンプトを立ち上げて、以下のコマンドでバージョンが表示されるかどうかで確認することがおすすめです。
なぜ管理者でのシェルの実行をおすすめするかというと、Windows 10 Pro 22H2で、管理者としてではなく普通に実行したシェルではwingetコマンドが認識されず実行できないことがあったからです。(この問題の修正方法はこちら)
ちなみに、wingetがインストールされているかを確認する他の方法としては、以下の2つもあります。
全選択はC-x hか、もしくは、メニューから
emacsで全選択するには
C-x h
。emacsでは全選択はときどきしかしないため、このキーバインドはなかなか覚えないなと思っていたら、
メニューバーを使うやり方の記事を見つけました。
確かにメニューバーに覚えておいてもらうのも1つの手だなと思いました。
タブを区別して表示する
ちなみに、タブが混入していたときに、一括して空白に置き換えるには
M-x untabify
。 emacsで見ると綺麗にインデントされているが実は空白とタブがグチャグチャになっているようなファイルを空白に統一するときにとても便利です。参考
https://flex.phys.tohoku.ac.jp/texi/emacs-jp/emacs-jp_104.html