前スレ
PowerShell -Part 6
https://mevius.5ch.net/test/read.cgi/tech/1644744972/
次スレは>>980が立ててね!!
PowerShell -Part 7
1デフォルトの名無しさん
2023/11/29(水) 16:07:49.46ID:0g8RZ7sB645デフォルトの名無しさん
2025/11/18(火) 17:30:44.99ID:d9hs+rsN それパイプは直感的に書けるか?
646デフォルトの名無しさん
2025/11/20(木) 16:43:19.74ID:11rVJeas 5ってまだ共存してるの?UTF8BOMの問題があるのでcmdでも使えばいい気がするが
647デフォルトの名無しさん
2025/11/20(木) 17:49:39.55ID:UDbnkgrO PowerShellは速度も使い勝手もこのbatに勝てなかった
@echo off
%windir%\Microsoft.NET\Framework64\v4.0.30319\csc.exe /nologo %1
if errorlevel 1 exit /b
"%~dpn1.exe"
@echo off
%windir%\Microsoft.NET\Framework64\v4.0.30319\csc.exe /nologo %1
if errorlevel 1 exit /b
"%~dpn1.exe"
648デフォルトの名無しさん
2025/11/20(木) 21:31:44.69ID:QY1RnXH9 C#はPowerShellみたいにWMIを簡単に扱えないじゃん
WMI インスタンスの取得
https://learn.microsoft.com/ja-jp/windows/win32/wmisdk/retrieving-an-instance
WMI インスタンスの取得
https://learn.microsoft.com/ja-jp/windows/win32/wmisdk/retrieving-an-instance
649デフォルトの名無しさん
2025/11/21(金) 09:24:25.92ID:+qc1E8Ol 比較
OS標準だとC#は古いやり方しかできなそう
<PowerShell>
Get-WmiObject -query "SELECT * FROM Win32_Process" | ForEach-Object {
$name = $_.Name
$id = $_.ProcessId
. . .
}
<C#>
foreach (var p in new System.Management.ManagementObjectSearcher("SELECT * FROM Win32_Process").Get())
{
var name = p["Name"];
var id = p["ProcessId"];
. . .
}
OS標準だとC#は古いやり方しかできなそう
<PowerShell>
Get-WmiObject -query "SELECT * FROM Win32_Process" | ForEach-Object {
$name = $_.Name
$id = $_.ProcessId
. . .
}
<C#>
foreach (var p in new System.Management.ManagementObjectSearcher("SELECT * FROM Win32_Process").Get())
{
var name = p["Name"];
var id = p["ProcessId"];
. . .
}
650デフォルトの名無しさん
2025/11/21(金) 10:03:57.43ID:3+xXClvM >>640
最初は分けて書いてるがそれ以降のPowershellが
Windows 付かない方のPowershell 限定なのか
Windows 付く方も含めてなのかよくわからない
>>641
無印 は.Net Framework 向けでないという表現なのか
無印も.Net Frameworkだめというのかどっちなのか
.NET Framework上で動くのがWindows Powershell
3.5.1(まだある) + 2(廃止)
4.8.1 + 5.1 現行のプリインストール
.NET 上で動くのがPowershell
core2or3 + 6-7.0
5.0 + 7.1 以降
やはり改めて確認しないとわからない
なんで分かりやすい別の名前にしなかったのか
最初は分けて書いてるがそれ以降のPowershellが
Windows 付かない方のPowershell 限定なのか
Windows 付く方も含めてなのかよくわからない
>>641
無印 は.Net Framework 向けでないという表現なのか
無印も.Net Frameworkだめというのかどっちなのか
.NET Framework上で動くのがWindows Powershell
3.5.1(まだある) + 2(廃止)
4.8.1 + 5.1 現行のプリインストール
.NET 上で動くのがPowershell
core2or3 + 6-7.0
5.0 + 7.1 以降
やはり改めて確認しないとわからない
なんで分かりやすい別の名前にしなかったのか
651デフォルトの名無しさん
2025/11/22(土) 10:00:08.95ID:X6U8TT// WMIって非推奨なんだっけ
普通に業務で使ってるけど
普通に業務で使ってるけど
652デフォルトの名無しさん
2025/11/22(土) 15:21:40.53ID:LaYCYKWP Windows クライアントの非推奨の機能
https://learn.microsoft.com/ja-jp/windows/whats-new/deprecated-features
WMIC ユーティリティは非推奨となり、今後の Windows リリースで削除される予定です。 このユーティリティは、WMI のWindows PowerShellに置き換えられます。 この非推奨は、 コマンド ライン管理ユーティリティにのみ適用されます。 WMI 自体は影響を受けません。
https://learn.microsoft.com/ja-jp/windows/whats-new/deprecated-features
WMIC ユーティリティは非推奨となり、今後の Windows リリースで削除される予定です。 このユーティリティは、WMI のWindows PowerShellに置き換えられます。 この非推奨は、 コマンド ライン管理ユーティリティにのみ適用されます。 WMI 自体は影響を受けません。
653デフォルトの名無しさん
2025/11/22(土) 19:36:43.52ID:F8YvH3R6 wmiなくなる話はないが使い方変わってる
Powershell 6以降WMI v1コマンドレット無い
今のところWindows Powershell 無くす話はないが
書き直すならPowershell でCIM (WMI v2)コマンドレットにしておいた方が無難?
https://learn.microsoft.com/ja-jp/powershell/scripting/whats-new/differences-from-windows-powershell?view=powershell-7.5#wmi-v1-cmdlets
Powershell 6以降WMI v1コマンドレット無い
今のところWindows Powershell 無くす話はないが
書き直すならPowershell でCIM (WMI v2)コマンドレットにしておいた方が無難?
https://learn.microsoft.com/ja-jp/powershell/scripting/whats-new/differences-from-windows-powershell?view=powershell-7.5#wmi-v1-cmdlets
654デフォルトの名無しさん
2025/11/26(水) 15:45:38.37ID:0sOrUy4b PowerShell のプログラムで時々見かける
if ( hoge ) {
hogehoge
}
else {
fugafuga
}
みたいな
elseのところを2行に書く書き方が気持ち悪いし
PowerShell にコピペでインタプリタ的に実行させると閉じ括弧で構文が終わったと判断されて実行されちゃう
(さらに外側に括弧があれば構文として成り立つけど)
if ( hoge ) {
hogehoge
}
else {
fugafuga
}
みたいな
elseのところを2行に書く書き方が気持ち悪いし
PowerShell にコピペでインタプリタ的に実行させると閉じ括弧で構文が終わったと判断されて実行されちゃう
(さらに外側に括弧があれば構文として成り立つけど)
655デフォルトの名無しさん
2025/11/27(木) 10:58:01.72ID:iSxBbXck オレは気持ち悪いと思ったことない
言語特有の文法とか個人個人の書き方とか色々あるし
それで別にいいじゃんって思ってる
仕事でプログラムやスクリプト使ってる人たちは
その職場のルールもあるだろうけど
素直に従っておけばいいだけ
改良の余地があるなら進言するだけだし
言語特有の文法とか個人個人の書き方とか色々あるし
それで別にいいじゃんって思ってる
仕事でプログラムやスクリプト使ってる人たちは
その職場のルールもあるだろうけど
素直に従っておけばいいだけ
改良の余地があるなら進言するだけだし
656デフォルトの名無しさん
2025/11/27(木) 12:30:08.06ID:Z/DnqSSi 普通じゃないし普通に気持ち悪いだろ
657デフォルトの名無しさん
2025/11/27(木) 12:58:20.26ID:tq5aNNAF ベストプラクティスにはそこまで細かい規約なかった
https://learn.microsoft.com/en-us/powershell/scripting/developer/cmdlet/strongly-encouraged-development-guidelines
C#、明示されてないがサンプルは三行
これに準じると閉じてエンターで走る
https://learn.microsoft.com/ja-jp/dotnet/csharp/fundamentals/coding-style/coding-conventions
https://learn.microsoft.com/en-us/powershell/scripting/developer/cmdlet/strongly-encouraged-development-guidelines
C#、明示されてないがサンプルは三行
これに準じると閉じてエンターで走る
https://learn.microsoft.com/ja-jp/dotnet/csharp/fundamentals/coding-style/coding-conventions
658デフォルトの名無しさん
2025/11/27(木) 15:27:32.59ID:Z/DnqSSi 普通(既存宗教):
} else {
または
}
else
{
奇形(新興宗教):
}
else {
} else {
または
}
else
{
奇形(新興宗教):
}
else {
659デフォルトの名無しさん
2025/11/27(木) 15:30:06.19ID:Z/DnqSSi660デフォルトの名無しさん
2025/11/27(木) 15:39:55.59ID:o+yFQZuV661デフォルトの名無しさん
2025/11/27(木) 16:35:40.04ID:/I+q4k2H powershell民なら
} else
と書いておく
こうすると解釈が延長するわけでelse節が無ければ次行で
{}
と書いて終わらすこともできる
これはpowershell民に限らず行志向言語の常識的イディオム
} else
と書いておく
こうすると解釈が延長するわけでelse節が無ければ次行で
{}
と書いて終わらすこともできる
これはpowershell民に限らず行志向言語の常識的イディオム
662デフォルトの名無しさん
2025/11/27(木) 16:51:14.83ID:o+yFQZuV663デフォルトの名無しさん
2025/11/27(木) 16:53:53.08ID:o+yFQZuV ああ、インタープリタ的な使い方ってことか
664デフォルトの名無しさん
2025/11/27(木) 16:58:55.38ID:o+yFQZuV ならとりあえず
} else {
と書いておくほうが良い気がする
} else {
と書いておくほうが良い気がする
665デフォルトの名無しさん
2025/11/27(木) 21:48:18.93ID:L4seW1+I elseは使わないようにする
666デフォルトの名無しさん
2025/11/27(木) 23:03:58.47ID:0ZpriLCv 5.xは三項演算子がないので他の言語よりelseを使う機会が多くなりがち
667デフォルトの名無しさん
2025/11/28(金) 10:07:39.92ID:YEOTrRQk Weekend Scripter: Best Practices for PowerShell Scripting in Shared Environment
https://devblogs.microsoft.com/scripting/weekend-scripter-best-practices-for-powershell-scripting-in-shared-environment/#use-consistent-indentation
PowerShellのコーディングスタイル
https://tech.guitarrapc.com/entry/2017/12/03/230119
https://devblogs.microsoft.com/scripting/weekend-scripter-best-practices-for-powershell-scripting-in-shared-environment/#use-consistent-indentation
PowerShellのコーディングスタイル
https://tech.guitarrapc.com/entry/2017/12/03/230119
668デフォルトの名無しさん
2025/11/28(金) 10:46:55.41ID:XwmNjHGjレスを投稿する
ニュース
- 『一貫している日本政府の立場があたかも変わったかのような主張を国内ですることは、中国を利することに』自民党広報が見解 [おっさん友の会★]
- 【芸能】長嶋一茂 高層ビル住民にパラシュートのススメ 香港火災を例に「理性を最後まで失わずに対処できる…」 [冬月記者★]
- 今後50年間、毎年100万人ずつ人口が減る…「少子化対策」の失敗で日本が迎える「死ぬまで搾取」というヤバい未来 [ぐれ★]
- 石破茂氏、「高市さんよくぞ言った」の空気に待った 存立危機事態…考えてはいても「公の場で言うことか」:東京新聞 ★2 [少考さん★]
- 25年の食品値上げ、2年ぶり2万品目超え [少考さん★]
- 【芸能】一青窈「久しぶりに間違われました」 病院での名前の“誤字”に『窃×→窈です』 [冬月記者★]
- 中国「誠意を見せる気があるなら高市早苗は辞任しろ。」キタ━(゚∀゚)━! [153490809]
- 【高市悲報】中国富裕層「売ろうかな」タワマンバブルが弾ける [709039863]
- 【悲報】橋下徹「高市氏自身は反省したが、熱烈支持者は発言を絶対正当化し続ける。その声に左右される国家運営は非常に危険 [733893279]
- この世で一番怖いものそれは
- 【高市悲報】中国、統一教会を邪教と位置付け、日米政界が統一教会に牛耳られているとみなしていた🏺😭 [359965264]
- モンハンワイルズ発売日から遊んで1週間で辞めたんやが
