1 名前:デフォルトの名無しさん mailto:sage [2022/02/13(日) 18:36:12.07 ID:LaQ04ZoE.net] 前スレ PowerShell -Part 5 https://mevius.5ch.net/test/read.cgi/tech/1615994992/ 次スレは>>980 が立ててね!!
708 名前:デフォルトの名無しさん mailto:sage [2023/02/19(日) 01:42:49.14 ID:15y14fHP.net] 数式のチェックをするということならusedrange.formulaとかで二次元配列に入れてしまえば速いだろうね
709 名前:デフォルトの名無しさん mailto:sage [2023/02/19(日) 07:28:37.93 ID:xSIr/CQB.net] セルの値をチェックしたいのか数式をチェックしたいのかもわからんしそもそも既に作ってあるならその遅い部分のコード晒せばいいのに としか思わん
710 名前:693 mailto:sage [2023/02/21(火) 12:34:29.62 ID:jIGEezda.net] PowerShellでRangeに対してforeachを使ったら糞遅かったが、Range.Cellsに対して使ったら爆速でした。 VBAで.Cellsを付けないことは無いが、PowerShellだと書き方が変わるから気付かんかった。 ソースは仕事で晒せないが、記憶を頼りに再現したのを後で書くよ。
711 名前:デフォルトの名無しさん mailto:sage [2023/02/21(火) 15:29:46.97 ID:y0oxbjUQ.net] やりたい内容によってはImportExcelとか使うといいかもしれない
712 名前:デフォルトの名無しさん mailto:sage [2023/02/21(火) 17:16:31.11 ID:mQxVjbPG.net] Excel操作は真面目にやるとCOMの参照の管理と解放が大変で避けちゃう。 完全に自分用なら雑でもいいんだけどさ。 VBScriptくらいに気楽にやらせて欲しい。
713 名前:デフォルトの名無しさん mailto:sage [2023/02/21(火) 18:44:18.75 ID:7Z23bFwT.net] あららSnoverさん去年退職しちゃったのか、、、 言語的には成熟してるし問題はないんだろうけど、残念だな
714 名前:デフォルトの名無しさん [2023/02/21(火) 19:36:25.83 ID:VTx8hARX.net] >>698 素直にExcel VBAを書いた方が安全だよ。
715 名前:デフォルトの名無しさん mailto:sage [2023/02/24(金) 13:12:14.11 ID:xAv3d2xt.net] gci -recでレジストリ検索出来るの便利だなって一昨日思った
716 名前:デフォルトの名無しさん mailto:sage [2023/02/27(月) 21:04:03.19 ID:5eoJ3K3o.net] 大規模な PowerShell モジュールは Install-Module での導入がオススメです https://jpwinsup.github.io/blog/2023/02/27/UserInterfaceAndApps/PowerShell/PowerShell-ImportModule-FunctionOverflow/ Windows PowerShell では、 1 セッションのうち利用できる関数 (Function) の数の上限を変数 $MaximumFunctionCount にて制御しており、既定では 4096 となります。 Import-Module にて PowerShell モジュールを導入しますと、この $MaximumFunctionCount で管理する関数の数にカウントされ 4096 を超えた場合にエラーが生じます。 Install-Module では、本事象は発生しませんので、Install-Module を、ご利用いただくことを推奨いたします。 単機能のモジュールであれば、今回のような制限が生じるほど大規模な関数 (Function) 数とならないですが、クラウド製品に対し提供されるモジュールは、大規模な関数数となる傾向がございます。 クラウド製品に対する PowerShell モジュールのご利用にはインターネット (オンライン) への接続が必須となりますため、Install-Module も利用可能でございます。
717 名前:デフォルトの名無しさん mailto:sage [2023/02/28(火) 21:55:58.18 ID:NXRHGwBO.net] vscodeのプラグインどうにかしてくれないかな せめて参照関連はちゃんとして欲しい
718 名前:デフォルトの名無しさん mailto:sage [2023/02/28(火) 23:08:46.00 ID:XEMkLhh3.net] PowerShellの構文が分からなくなったときに今話題のChatGPTで質問してみたら 的確な回答返ってきてすげぇ助かったわ。もうパソコン教室は廃業だろこれ
719 名前:デフォルトの名無しさん mailto:sage [2023/03/10(金) 20:16:52.26 ID:qXeg3GIX.net] ai のコード生成って結構すごいよね コパイロット入れてるんだが、マジで打とうとしたコード先読みしてくる インテリセンスみたいな数文字打って残りの補完じゃなくて、まるまる予測してきて更に当たってるっていう
720 名前:デフォルトの名無しさん mailto:sage [2023/03/15(水) 14:42:36.44 ID:o8REigww.net] ここでいいですか ttps://qiita.com/Midoliy/items/a033b763399c242dc5c5 C#をスクリプト言語として利用する方法 PowerShell 7.3.3 で、dotnet tool install -g dotnet-script を入力してもエラーになります↓ C:\Users\UserName0\AppData\Local\Temp\47744ec9-ca71-4312-b0e8-3f8bd18d5776\restore.csproj : error NU1101: パッケージ dotnet-scri pt が見つかりません。ソース Microsoft Visual Studio Offline Packages には、この ID のパッケージが存在しません。 ツール パッケージを復元できませんでした。 ツール 'dotnet-script' をインストールできませんでした。この失敗は次の原因で生じた可能性があります。 * プレビュー リリースをインストールしようとしており、--version オプションを使用してバージョンを指定しなかった。 * この名前のパッケージが見つかったが、.NET ツールではなかった。 * 恐らくインターネットの接続の問題で、必須の NuGet フィードにアクセスできない。 * ツールの名前の誤入力。 パッケージの名前付けの強制を含む他の理由については、https://aka.ms/failure-installing-tool にアクセスしてください
721 名前:デフォルトの名無しさん mailto:sage [2023/03/15(水) 15:33:19.80 ID:IBd2LSQO.net] そこ見てダメなら諦めたら 特にメリットないし
722 名前:デフォルトの名無しさん mailto:sage [2023/03/15(水) 21:33:00.90 ID:e2aqyp6Z.net] >>708 https://stackoverflow.com/questions/58012732/unable-to-find-package-no-packages-exist-with-this-id-in-source-net-core https://github.com/dotnet/sdk/issues/13429 を参考に英語のエラーメッセージでweb検索するとか。
723 名前:デフォルトの名無しさん mailto:sage [2023/03/17(金) 11:52:05.75 ID:1OmGmSd0.net] >>707 コパイロットとやらはインタラクティブシェルでも使える?興味あり gnureadlineうんこpsreadline最強と思ってたら思わぬ伏兵が… bingのchatgptが話題になってるし、標準で付いてもおかしくないけど
724 名前:デフォルトの名無しさん mailto:sage [2023/03/17(金) 14:15:57.93 ID:piFUHGnm.net] インタラクティブ(履歴)/スクリプトでもヒューリスティックにコンテキストを読んでくれるのは新しいね、もはや補完ではない気がするが ところで-UseFussyが超便利
725 名前:デフォルトの名無しさん mailto:sage [2023/03/19(日) 10:19:36.25 ID:+AVX1Caz.net] https://www.powershellgallery.com/packages?q=Copilot
726 名前:デフォルトの名無しさん mailto:sage [2023/03/27(月) 09:23:21.18 ID:qNF02T37.net] f1で直近コマンドの、Alt-hで直近パラメータのヘルプがコマンドラインを汚さずにチラ見出来るけど 常時表示しておきたい
727 名前:デフォルトの名無しさん mailto:sage [2023/03/28(火) 15:38:45.60 ID:vZrgWFuJ.net] >>714 https://learn.microsoft.com/en-us/powershell/scripting/learn/shell/dynamic-help?view=powershell-7.4 フックされてるShowCommandHelpあたりを改造してみては
728 名前:デフォルトの名無しさん mailto:sage [2023/03/31(金) 09:29:33.35 ID:Hum0KYCd.net] コマンドプロンプトのstartコマンドのように 新しいウィンドウを作成せず、使うプロセッサを指定して起動するにはどうすれば良いですか
729 名前:デフォルトの名無しさん [2023/03/31(金) 10:04:55.21 ID:oEDBXBHf.net] Add-Type によって、自作のクラスを使う処理を書いて、一応ちゃんと動くのですが 同じことを 何度もやろうとすると 二度目以降は「The type 〜 already exists.」と出て止まってしまいます. そこで「既に そのタイプが存在しているかどうか」をチェックしたいのですが、これってどう書くんでしょうか
730 名前:デフォルトの名無しさん mailto:sage [2023/03/31(金) 22:12:52.48 ID:yFMegc6R.net] >>717 こんなん Add-Type @' public class MyClass { public void test() { } } '@ if ("MyClass" -as [type]) { "MyClass is exist" }
731 名前:デフォルトの名無しさん mailto:sage [2023/03/31(金) 22:21:06.75 ID:bSGiEzAG.net] >>716 (Start-Process -PassThru foo.exe).ProcessorAffinity = xxx xxxの所で使いたいプロセッサを指定する Start-Process -PassThru https://learn.microsoft.com/ja-jp/powershell/module/microsoft.powershell.management/start-process#-passthru Process.ProcessorAffinity プロパティ https://learn.microsoft.com/ja-jp/dotnet/api/system.diagnostics.process.processoraffinity
732 名前:デフォルトの名無しさん mailto:sage [2023/03/31(金) 22:35:53.19 ID:yFMegc6R.net] >>719 >新しいウィンドウを作成せず という指定が抜けてね?
733 名前:716 mailto:sage [2023/03/31(金) 22:58:55.98 ID:Hum0KYCd.net] >>717 単純に try { [クラス] } catch { Add-Type 〜 } とか、知らんけど >>719 Start-Processを使わない場合のように新しいウィンドウなしで起動したいです
734 名前:デフォルトの名無しさん mailto:sage [2023/03/31(金) 23:29:03.95 ID:bSGiEzAG.net] https://learn.microsoft.com/ja-jp/powershell/module/microsoft.powershell.management/start-process#-nonewwindow -NoNewWindow 現在のコンソール ウィンドウで新しいプロセスを開始します。 Windows では、既定で PowerShell によって新しいウィンドウが開きます。
735 名前:716 mailto:sage [2023/03/31(金) 23:54:48.86 ID:Hum0KYCd.net] >>722 最初はそれでいいと思ったんですが、コンソールの取り合いになります (Start-Process netsh.exe -NoNewWindow とかで試すとわかりますが、くれぐれもご注意を) 取り合いにならないように -Wait も指定して (Start-Process netsh.exe -NoNewWindow -Wait -PassThuru).ProcessorAffinity = xxx とすると、-Wait が効きすぎて ProcessorAffinity をセットできないという罠
736 名前:デフォルトの名無しさん mailto:sage [2023/04/01(土) 00:12:16.16 ID:rM0w1xSL.net] つまり.NETのProcessorAffinityは存在するプロセスにしか適用できないから無理でいんじゃね 知らんけどWin32APIとかで別の方法を探った方がいいんじゃね
737 名前:デフォルトの名無しさん mailto:sage [2023/04/01(土) 00:25:58.89 ID:rM0w1xSL.net] たとえばWin32APIのCreateProcessにCREATE_SUSPENDEDというフラグがある プロセスをサスペンド状態で作成してaffinity設定してからResumeThreadで開始 これでいけるんじゃね
738 名前:デフォルトの名無しさん mailto:sage [2023/04/01(土) 03:49:24.51 ID:tD9Ph5o/.net] Start-Jobの中で実行したら上手いこと裏でやってくれないだろうか
739 名前:デフォルトの名無しさん mailto:sage [2023/04/01(土) 09:42:35.62 ID:nbrNF8T0.net] Start-Process -NoNewWindow cmd.exe "/c start /affinity xxx /b foo.exe" これくらいしか思い浮かばなかった
740 名前:デフォルトの名無しさん mailto:sage [2023/04/01(土) 10:09:29.22 ID:rM0w1xSL.net] 定義が長くなったからこっちに貼り付けたよ https://ideone.com/LOSuzD 使い方 bool [Win32API]::CreateProcessWithAffinity(appname, cmdline, affinity) affinityはプロセスに直接設定するAPIが見つからなかったのでGet-ProcessをResumeThread前に呼び出して指定してる サンプルはcmdを呼び出してpingをlocalhostに10回打ってる間にプロセス名とaffinity値を出してる
741 名前:727 mailto:sage [2023/04/01(土) 10:22:16.44 ID:nbrNF8T0.net] Start-Process -NoNewWindow -Wait cmd.exe "/c start /affinity xxx /b foo.exe" こうだった
742 名前:デフォルトの名無しさん mailto:sage [2023/04/01(土) 10:27:57.30 ID:rM0w1xSL.net] 寝ぼけてた。コールバックの部分下だけで良かったわ System.Diagnostics.Process.GetProcessById(pInfo.dwProcessId).ProcessorAffinity = (IntPtr)affinity;
743 名前:デフォルトの名無しさん mailto:sage [2023/04/01(土) 10:32:18.54 ID:rM0w1xSL.net] でもう一箇所、appnameに$nullを指定してもC#側型宣言で""に変換されてしまうので、CreateProcessの直前に下を追加しとくとcmdlineだけで動く if (appname == "") { appname = null; }
744 名前:デフォルトの名無しさん mailto:sage [2023/04/01(土) 10:52:36.56 ID:NrUMzMDg.net] これパイプすればいいんだよ ポイントは () を使わないこと (Start-Process).ProcessorAffinity = xxx は NG Start-Process | ForEach-Object {} で OK (Start-Process) | ForEach-Object {} は NG & { Start-Process } | ForEach-Object {} でも OK
745 名前:デフォルトの名無しさん mailto:sage [2023/04/01(土) 11:09:34.29 ID:rM0w1xSL.net] >>732 これ正解じゃない? 遠回りしたねえ
746 名前:デフォルトの名無しさん mailto:sage [2023/04/01(土) 11:10:53.22 ID:rM0w1xSL.net] Start-Process cmd.exe -ArgumentList '/c echo hello world & ping 127.0.0.1 -n 10' -NoNewWindow -PassThru | %{ $_.ProcessorAffinity = 1; $_ | select Name, ProcessorAffinity }
747 名前:デフォルトの名無しさん mailto:sage [2023/04/01(土) 14:38:06.95 ID:khXUWf7f.net] Start-Process cmd.exe -NoNewWindow -PassThru | % { $_.ProcessorAffinity = 1 } だと困る Start-Process cmd.exe -NoNewWindow -PassThru -Wait | % { $_.ProcessorAffinity = 1 } か Start-Process cmd.exe -NoNewWindow -PassThru | % { $_.ProcessorAffinity = 1; Wait-Process -Id $_.Id }
748 名前:デフォルトの名無しさん [2023/04/01(土) 16:54:32.28 ID:SzOWT/hN.net] 717です. 反応してくださったかた ありがとうございました >>718 if ("MyClass" -as [type]) → なるほど!…これでした! >>721 私も,とりあえずは try{ [MyClass] >$null } catch{ Add-Type -Path "〜.cs" >$null } で 済ませていたのですが 例外に たよる書き方は,なんとなくカッコ悪い感じがして(笑)
749 名前:デフォルトの名無しさん mailto:sage [2023/04/01(土) 21:56:00.86 ID:sdpm0Gxz.net] >>716 (Start-Process -FilePath 〜〜〜 -ArgumentList 〜〜〜 -WindowStyle Hidden
750 名前: -PassThru).ProcessorAffinity = 1 [] [ここ壊れてます]
751 名前:デフォルトの名無しさん mailto:sage [2023/04/01(土) 22:32:49.48 ID:khXUWf7f.net] それでは Start-Process を使わない場合と違って入力も出力もできない
752 名前:デフォルトの名無しさん mailto:sage [2023/04/01(土) 22:58:19.34 ID:sdpm0Gxz.net] あ〜、 > コマンドプロンプトのstartコマンドのように > 新しいウィンドウを作成せず、使うプロセッサを指定して起動するにはどうすれば良いですか というか 新しいウィンドウを作成せず、 コマンドプロンプトのstartコマンドのように使うプロセッサを指定して起動するにはどうすれば良いですか という感じか。であればこれまでに出てた回答の方が正しいね。 ほぼ同じだけど自分なら $proc = Start-Process -FilePath 〜 -NoNewWindow -PassThru; $proc.ProcessorAffinity = 1; $proc.WaitForExit(); みたいにするかなぁ。(でもStart-Processじゃなく小回りのきくProcessStartInfoを使うかな?)
753 名前:デフォルトの名無しさん mailto:sage [2023/04/02(日) 00:15:44.70 ID:l9+T+h5c.net] 質問です。 外部コマンドの標準出力やエラー出力を一緒に変数に入れたいのですが、 $result=外部コマンド.exe 2>&1 この式で一見動作はしてるようのですが、外部コマンドからエラー出力があった場合に赤い色が付き、powershell的なエラーメッセージも追加されてしまいます。 意図としては色とか追加メッセージとかは不要で、純粋に外部コマンドの標準出力やエラー出力を一緒に変数に取り込みたいだけなのですが、 そういう場合どう記述したら良いでしょうか。
754 名前:デフォルトの名無しさん mailto:sage [2023/04/02(日) 00:47:59.12 ID:h0WbN+8B.net] 外部コマンドの引数が不要またはシンプルなら、 簡単で分かりやすいのはcmd上で標準出力にする方法 $result=cmd /c "外部コマンド.exe 2>&1"
755 名前:デフォルトの名無しさん mailto:sage [2023/04/02(日) 01:46:53.77 ID:l9+T+h5c.net] >>741 cmd脱却を考えているので、できればpowershell流?の書き方があればお願いいたします
756 名前:デフォルトの名無しさん mailto:sage [2023/04/02(日) 03:44:54.54 ID:byiZ93ic.net] >>742 Powershellでcmdを使いこなす技術を鍛えたほうが幸せになれると思うよ
757 名前:デフォルトの名無しさん mailto:sage [2023/04/02(日) 11:17:09.81 ID:l9+T+h5c.net] ためしにChatGPTに質問してみたら以下の回答でした 質問「powershell上から外部コマンドを実行し、その標準出力とエラー出力を、powershellによる出力の加工を抑止した状態で1つの変数に入れたい」 $output = & <コマンド> 2>&1 | Out-String Out-Stringは盲点でした。一応文字列として取得できているのでこれでいいのかな
758 名前:デフォルトの名無しさん mailto:sage [2023/04/02(日) 11:29:33.76 ID:yOzYb5by.net] PowerShellはあてにならないからcmdに頼ることも多いよな Write-Host Test 1 New-Item -Path target1 -ItemType Directory New-Item -Path junction1 -ItemType Junction -Value target1 Write-Host Test 2 New-Item -Path test2 -ItemType Directory Push-Location -Path test2 New-Item -Path target2 -ItemType Directory New-Item -Path junction2 -ItemType Junction -Value target2 これが失敗するなんて想像してなかった
759 名前:デフォルトの名無しさん mailto:sage [2023/04/02(日) 15:23:02.64 ID:9IrG8+0n.net] >>745 PowerShell5.1だと失敗しないな 7.3は駄目だった ターゲットのパスを絶対パスにすれば作れる New-Item -ItemType Junction can't create relative link #18251 https://github.com/PowerShell/PowerShell/issues/18251
760 名前:デフォルトの名無しさん mailto:sage [2023/04/02(日) 16:46:18.09 ID:yOzYb5by.net] ジャンクションなら絶対パス必須でもいいけど シンボリックリンクでは相対パスが使えないと不便 >>745 のテストをシンボリックリンクに変えてもやっぱりおかしい ターゲットがディレクトリなのにファイルのシンボリックリンクになる 条件次第で逆にすることもできる タイプ間違いだと補完や削除をするときに困るんだよな だから最初からcmd.exeでmklinkしてる
761 名前:デフォルトの名無しさん mailto:sage [2023/04/02(日) 21:47:00.28 ID:9IrG8+0n.net] Target type detection (file/directory) for relative symlinks is still broken, even on Windows #15235 https://github.com/PowerShell/PowerShell/issues/15235 これか? 2年前に立ったissueなのにまだ直ってないみたい
762 名前:デフォルトの名無しさん mailto:sage [2023/04/03(月) 07:48:59.39 ID:Jr4h81FG.net] >>739 あの〜、コマンドプロンプトのstartだと1行の start /B /AFFINITY 1 cmd.exe のように「新しいウィンドウを作成せず、使うプロセッサを指定して起動する」には 小回りのきくProcessStartInfoを使うとどう書くの?
763 名前:デフォルトの名無しさん mailto:sage [2023/04/03(月) 08:48:40.85 ID:hrmFy8ir.net] .NETでの普通のやり方ならググるれば出てくるよ
764 名前:デフォルトの名無しさん mailto:sage [2023/04/03(月) 21:13:34.50 ID:d+sLTFCG.net] 例示ではプロセス起動・Process型オブジェクト取得にStart-Processを使ったけど >>739 は普段はProcessStartInfo使ってるってだけじゃないの。 私も引数あるときはStart-Process(-ArgumentList)避けてProcessクラス使う。
765 名前:デフォルトの名無しさん mailto:sage [2023/04/03(月) 21:20:59.87 ID:9kyxsKiX.net] PowerShellってWebスクレイピングには向いてないですか? Pythonで作った方がいいですか? PowerShellは職場用のスクリプトを何個か作ったりして少し分かるのですが、Pythonはまったく不慣れなので迷ってます
766 名前:デフォルトの名無しさん mailto:sage [2023/04/03(月) 21:35:29.28 ID:NHigh4Tg.net] Poweshellでちょっスクレイピング sloppy-content.blog.jp/archives/12057529.html 【PowerShell】SeleniumモジュールでWebスクレイピングしたい https://zenn.dev/hara_power/articles/815e3f3dc1e5655c4c22
767 名前:デフォルトの名無しさん mailto:sage [2023/04/03(月) 22:09:14.13 ID:FTaZkaBO.net] Windowsに限ればスクレイピング以外にもブラウザに直接細工する手段が充実してるからライブラリ頼みのpythonより向いてるとも言える
768 名前:752 mailto:sage [2023/04/04(火) 10:40:01.35 ID:4xPC11r9.net] >>753 >>754 ありがとうございます PowerShellでやってみようと思います
769 名前:デフォルトの名無しさん mailto:sage [2023/04/08(土) 22:48:22.89 ID:wqsbQ+QM.net] PowerShellでPersonal Communicationsを操作しようと思い 以下のサイトを参考にしようとしたのですが https://www.tekizai.net/entry/2021/10/04/063000 64bit版のPowershellでは出来ないようです 64bit版でも動かせるように変更はできないでしょうか?
770 名前:デフォルトの名無しさん mailto:sage [2023/04/08(土) 23:26:55.43 ID:ymsLMaB3.net] 64bit環境用のPersonal CommunicationsのOCXやらが無い場合は32bitのpowershellからCreateObjectするしかないとは思うけど そのサイトのVBA版では環境に関する言及がないね 32bit版Officeを使っているという前提で書いてるのかもしれないが試してみないと判らないね
771 名前:デフォルトの名無しさん [2023/04/10(月) 20:51:54.13 ID:4PCv5Fk3.net] すいません、当方SEで技術的な質問です administrator権限のユーザーでLinuxサーバーからパスワード認証でなく、秘密鍵と認証鍵の認証方式でwindowsサーバーにSSHを掛けたいのですが、administrator権限のユーザーですと、パスワードを聞かれてしまいます 他の権限のユーザーは問題無く認証されます administrator権限では認証方式のSSHは使えないのでしょうか?
772 名前:デフォルトの名無しさん mailto:sage [2023/04/10(月) 21:12:02.69 ID:bM8RH+P4.net] >>758 superuser.com/questions/1407020/ddg#1407042
773 名前:デフォルトの名無しさん [2023/04/10(月) 21:31:04.64 ID:4PCv5Fk3.net] >>759 ありがとうございます 明日、業務で試してみます
774 名前:デフォルトの名無しさん mailto:sage [2023/04/14(金) 21:40:03.65 ID:qiPEiEw+.net] Windowsのディスプレイ設定で拡大率を100%以外にしてると フォームの文字がぼやけるんだけど、なにか解決策はありますか? Add-Type -AssemblyName System.Windows.Forms Add-Type -AssemblyName System.Drawing $form = New-Object System.Windows.Forms.Form $form.text= "タイトルはぼやけない" $label = New-Object System.Windows.Forms.Label $label.Size = New-Object System.Drawing.Size(300,20) $label.Text = "ディスプレイ拡大率が100%以外だと文字がぼやける" $form.Controls.Add($label) $form.ShowDialog()
775 名前:デフォルトの名無しさん mailto:sage [2023/04/14(金) 21:40:32.33 ID:qiPEiEw+.net] ちなみにOSはWindows11です
776 名前:デフォルトの名無しさん mailto:sage [2023/04/15(土) 13:51:30.62 ID:iq3ZlEDB.net] その辺て外人もあまり正解に辿り着いてない箇所だな 俺も辿り着いたとは言えんけど面倒だった
777 名前:デフォルトの名無しさん mailto:sage [2023/04/15(土) 14:12:07.08 ID:ig+gwe+P.net] C#を使うのが最適解
778 名前:デフォルトの名無しさん mailto:sage [2023/04/15(土) 15:02:15.83 ID:cOO792TH.net] powershellじゃなくてWindowsFormsの問題でしょ 「WindowsForms ぼやけ」で検索したらいくらでも出てきたけど
779 名前:デフォルトの名無しさん mailto:sage [2023/04/15(土) 19:25:15.71 ID:erslMsE0.net] WPFで作れば違うのか?
780 名前:デフォルトの名無しさん mailto:sage [2023/04/15(土) 20:21:51.02 ID:iq3ZlEDB.net] ちょっと意識して組めばできなくはないから環境を変える程でもないな
781 名前:デフォルトの名無しさん mailto:sage [2023/04/15(土) 22:14:25.62 ID:raQFwlCG.net] c:\aaa\bbb\ccc\hhh c:\aaa\ddd\eee c:\aaa\fff\ggg(以下続く) というフォルダ構造があった場合、ccc(サブフォルダhhhも含む)、eee、gggのフォルダを別のフォルダにコピーしたいんですがうまくいきません。 chatGPTに聞いたところ ($rootFolder=c:\aaa、$targetFolderはコピー先) $targetFolders = Get-ChildItem $rootFolder -Recurse -Directory | Where-Object { $_.FullName -like "$rootFolder\*\*\[ceg]" } となり、少し変更して $targetFolders = Get-ChildItem $rootFolder -Recurse -Directory | Where-Object { $_.FullName -like "$rootFolder\*\*" } としてみたんですが、これだとcccフォルダがコピー先に存在していた場合hhhフォルダがcccフォルダとは別にコピーされてしまいます。 同じフォルダ名があった場合サブフォルダの処理を飛ばしてフォルダ構造したままコピーする方法はないでしょうか。
782 名前:デフォルトの名無しさん mailto:sage [2023/04/15(土) 22:16:07.91 ID:raQFwlCG.net] フォルダ構造したまま→フォルダ構造を維持したまま 失礼しました。
783 名前:デフォルトの名無しさん mailto:sage [2023/04/15(土) 23:22:30.72 ID:iq3ZlEDB.net] ・同じフォルダ名があった場合サブフォルダの処理を飛ばしたい ってう制約を加えてchatGPTに聞いたらいいんじゃね
784 名前:768 mailto:sage [2023/04/16(日) 01:08:07.22 ID:i+x2SgN3.net] >>770 試してますがうまくいきませんね。aaaやbbbが例えであることをうまく理解してくれなくて、 全てのフォルダ名を手入力する必要があるコードしか作ってくれません。○や△みたいな記号に置き換えても同じ。 get-childitemで特定の深さ以下のフォルダ名を取得することができればうまく行きそうですが、 -depthは特定の深さ「まで」のフォルダを検索するオプションですよね? 特定の深さ以下のフォルダを検索する方法はありませんか?
785 名前:デフォルトの名無しさん mailto:sage [2023/04/16(日) 11:56:14.63 ID:QYDIaDii.net] 一発でrecursiveでやるのを諦めて泥臭く2重なり3重なりの繰り返し処理にして 自分でフォルダを掘り下げていけばいいんじゃないの
786 名前:デフォルトの名無しさん mailto:sage [2023/04/16(日) 11:57:11.68 ID:QYDIaDii.net] 深さが動的なら関数にして再帰呼び出し
787 名前:デフォルトの名無しさん mailto:sage [2023/04/16(日) 12:07:35.90 ID:Gz6gIEIr.net] >>771 「特定の深さ以下」ではなく「特定の深さ直下」を対象としたいんだよね?
788 名前:デフォルトの名無しさん [2023/04/16(日) 12:38:10.68 ID:SPigkToS.net] >>771 相対パスの概念がないのか?
789 名前:デフォルトの名無しさん [2023/04/16(日) 12:47:20.03 ID:SPigkToS.net] >>768 はネタかもな コピー先に何があるのかチェックしないという発想は、まったく理解できない。 初心者なら前提条件という概念がないのはわかる。 先にあったらこうする、そうでなかったらこうするなどの条件分岐がないなら、強引にやればいい。 そもそもROBOCOPYコマンドでできることをやろうとしているのは、これ学校の課題なのかなと思いました。
790 名前:デフォルトの名無しさん mailto:sage [2023/04/16(日) 15:01:28.21 ID:EhcVUpdk.net] 深さ3のディレクトリをそのままコピーすりゃいいだけじゃないの?
791 名前:768 mailto:sage [2023/04/17(月) 01:51:03.87 ID:GaP+UugE.net] >>774 そうなんですが、>>768 だとd:\コピー先\ccc\hhhとしたいのにcccフォルダがすでにあると d:\コピー先\ccc d:\コピー先\hhhになっちゃうんですよね。 >>772 の方法か、もしくは>>776 robocopyとforeachで何とかできるか? とりあえず自分であがいてみます。
792 名前:デフォルトの名無しさん mailto:sage [2023/04/17(月) 02:46:16.45 ID:dBG5z/eM.net] 入出力をちゃんと定義できてないからおかしな事になる初心者あるあるだな
793 名前:デフォルトの名無しさん mailto:sage [2023/04/17(月) 11:31:05.75 ID:udj2SRYX.net] 特定の深度だけ処理してみた ※$Sourceはフルパス指定であること param( [string] $Source, # $Sourceからの相対深度 [int] $RelativityDepth ) # パスを\と/で区切って配列化 $SourceDirSplit = $Source.Split([System.IO.Path]::DirectorySeparatorChar).Split([System.IO.Path]::AltDirectorySeparatorChar) foreach ($TargetDir in @(Get-ChildItem -LiteralPath $Source -Recurse -Directory)) { # パスを\と/で区切って配列化 $TargetDirSplit = $TargetDir.FullName.Split([System.IO.Path]::DirectorySeparatorChar).Split([System.IO.Path]::AltDirectorySeparatorChar) # 指定深度にあるDirを処理 if ($TargetDirSplit.Count -eq ($SourceDirSplit.Count + $RelativityDepth)) { # 一致したディレクトリを返す $TargetDir } }
794 名前:デフォルトの名無しさん mailto:sage [2023/04/19(水) 22:39:13.81 ID:CpwHPFTk.net] Start-ThreadJob や Register-EngineEvent のスクリプトブロックの中で キャプチャされずにWrite-Output 相当の出力をする方法はないでしょうか パイプラインに流したいので Write-Host ではなく Write-Output したいです 別のプロセスを経由する方法は思いついたのですが残念過ぎますし ForEach-Object -Parallel のようにキャプチャされなければ良いのに function hogepiyo { begin { 処理本体はここで Start-ThreadJob しておく } process { … } end { … } clean { … } } なんちゃら | hogepiyo | ぽげむた のようにしたくて考えてます 要は入出力と処理を非同期にできれば他の方法でもありがたいです
795 名前:デフォルトの名無しさん mailto:sage [2023/04/20(木) 22:12:24.17 ID:dJqrvGvM.net] キャプチャとか何言ってるのかわからない
796 名前:デフォルトの名無しさん mailto:sage [2023/04/20(木) 22:40:35.29 ID:fUuxiSJs.net] PowerShellでフォーム作るの割と苦痛なんだけど何かデザインモードとかないの?
797 名前:デフォルトの名無しさん mailto:sage [2023/04/21(金) 05:21:56.20 ID:ZJfuu8vu.net] Where-object多様するスクリプトに数万行のcsv食わせたら処理に1時間くらいかかる… 大量のデータ処理はWhere-object使うなってみかけたけど使わん方がいいのか
798 名前:デフォルトの名無しさん mailto:sage [2023/04/21(金) 07:34:50.39 ID:TBBX4m6H.net] 件数が少ないことが確実な時しか使わない。 スクリプトだとほとんど foreach(){} 使ってる。 パイプライン処理したい場合でも &{} や .{} や function の process{} あるいは filter。
799 名前:デフォルトの名無しさん mailto:sage [2023/04/21(金) 09:17:07.60 ID:kA/+t8w0.net] >>783 PowerShell Pro Tools https://ironmansoftware.com/powershell-pro-tools
800 名前:デフォルトの名無しさん mailto:sage [2023/04/21(金) 11:30:54.75 ID:c3fakvC2.net] >>784 PowerShell スクリプトのパフォーマンスに関する考慮事項 ttps://learn.microsoft.com/ja-jp/powershell/scripting/dev-cross-plat/performance/script-authoring-considerations?view=powershell-7.3
801 名前:デフォルトの名無しさん mailto:sage [2023/04/21(金) 17:50:40.46 ID:4gKwO2KA.net] >>782 出力がコレクションにためられて Receive-Job が必要になるのを回避したい Start-ThreadJob の -StreamingHost オプションの Write-Output 版な感じ そんなオプションはないから回避方法を知りたい Start-TheadJobだけでなくイベントハンドラから出力する場合も同じ イベント飛ばせばいいかと思ったらハンドラがジョブ扱いされて頭抱えた どうすれば Receive-Job を必要とせずに Write-Output 相当の出力ができるのだろう
802 名前:デフォルトの名無しさん mailto:sage [2023/04/21(金) 18:06:57.94 ID:xAAOLjx6.net] >>785 >>787 40万行処理するのに3時間かかったから作りなおすわ…
803 名前:デフォルトの名無しさん mailto:sage [2023/04/21(金) 19:56:34.84 ID:6pSKsEtx.net] >>788 Jobである必要がないならRunspacePoolでできるんじゃね
804 名前:デフォルトの名無しさん mailto:sage [2023/04/21(金) 21:03:30.48 ID:Vzmd1cD+.net] >>786 おお、あるのか来週会社で使ってみる ありがとう
805 名前:デフォルトの名無しさん mailto:sage [2023/04/22(土) 10:34:00.20 ID:iFkcYPBt.net] function target ・入力を読み続ける ・最後に読んだ入力を1秒間隔で出力し続ける ・入力が q なら終了 処理遅延を無視した理想的な使用例が . { $s = Get-Date; 1; sleep 3; 2; sleep 3; 'q' } | target | % { '{0} {1}' -f (Get-Date) - $s, $_ } 0:00:00.0000000 1 0:00:01.0000000 1 0:00:02.0000000 1 0:00:03.0000000 2 0:00:04.0000000 2 0:00:05.0000000 2 となるような function target はどうすれば実現できますか 処理時間でずれていくのはもちろんかまいませんが 入力待ちにも出力を続ける具体例が知りたいです
806 名前:デフォルトの名無しさん mailto:sage [2023/04/22(土) 10:36:10.71 ID:iFkcYPBt.net] おっと間違い (Get-Date) - $s でなく ((Get-Date) - $s) だ
807 名前:デフォルトの名無しさん mailto:sage [2023/04/22(土) 16:45:49.14 ID:3JkCsMe2.net] >>792 「qなら終了」が何を示すかによるが、powershellのパイプは途中で打ち切る事は原則できないと考えた方が良い。 (endブロックが呼ばれない不完全なハックならググれば見つかる) またパイプ処理の待機はpowershellのメインスレッドの待機という意味になるので、 そこに非同期イベントを介入させたい場合はそのイベント用の別スレッドを走らせておく必要がある。
808 名前:デフォルトの名無しさん [2023/04/22(土) 21:39:35.55 ID:81urZ/Lj.net] (New-Object -ComObject Shell.Application).NameSpace(10).MoveHere(ファイルパス) 上記の方法でファイルをごみ箱に移動する場合ファイルが1個なら問題ないんですが、 ファイルパスをを"z:\*"みたいにワイルドカードで指定するとなぜか ごみ箱でなくC:\Users\ユーザー名にファイルが送られてしまいます。 どうすればごみ箱に送れましょうか?