Windows PowerShell Part5 [無断転載禁止]©2ch.net
..◇・。..☆*。 ゜゜・*:..。.。★◎@ ○☆。..:*・゜ ゜゜・*:..。.。◇@☆*・゜★。。.:*・☆*・。..:*・゜ 。..:○★◎☆。∂∇。★◎*・゜゜。◎★ ◎☆◇☆。*・.。..☆◎。.:☆◇*.....。 ゜゜・*:..。.*・☆◎。__☆◎*・。..:*・゜ ゜ \ / \ / . ∧_∧\ / (´・ω・) ∞ >>1 乙(´・ω・) ス / つ つ△ 〜( ノ しし' 質問なのですが、以下のように「C:\Hoge\」に複数のテキストファイルがあるとします。(この例では3つ) C:\Hoge\ログ@.txt 1KB C:\Hoge\ログA.txt 5KB C:\Hoge\ログB.txt 3KB これらのテキストファイルの内容を全部つなげて以下のように1つのテキストファイルに出力したいのですが Powershellではどのように記述すればよいのでしょうか? C:\Hoge\ログALL.txt 9KB Get-Content C:\Hoge\ログ@.txt, C:\Hoge\ログA.txt, C:\Hoge\ログB.txt >> C:\Hoge\ログALL.txt >>7 レスありがとうございます。 ただ>>6 の例では3つですが、3つとは限らないんです。 つまり「C:\Hoge\*.txt」を全部つなげて「C:\Hoge\ログALL.txt」に出力したいんです。 >>7 さんのをヒントに考えるとGet-Child-Itemを使えばいいのかな?ちょっと自分でも考えてみます。 >>7 さんのヒントを元に試行錯誤したところ、以下で出来ました。 どうもありがとうございます! Get-Child-Item "C:\Hoge" | Get-Content | %{$_ >> "C:\Hoge\ログALL.txt"} 本当にできたんかね、Get-Child-Item なんて無いし作れもしないはずだが ついでに上の一行ごとに追加書き込みしててすごく遅そう これでいいんじゃ Get-ChildItem C:\Hoge\*.txt | Get-Content > C:\Hoge\all.txt Get-ChildItem C:\Hoge\*.txt | Get-Content | Add-Content C:\Hoge\ログALL.txt 問題起こして転職する奴が人の作ったスクリプトかっぱらって就活に利用しようとしてるんだけどコード的に防ぐ方法ってあるのかな。 >>13 所詮スクリプト、どんな対策をしたところで除去は容易。 第一、コード持ち出そうとしている奴へ今対策を打ったところで、既にそいつは対策前のコードをコピってるだろうから無意味。 次の会社にそいつがやらかしたことを教えてやる方が早い。 >>11 確かにこちらの方が高速ですね。どうもありがとうございます。これを使わせていただきます。 ご指摘の件は実際に動かしたコードを2chに書き込む時にエイリアスの「gci」を エイリアスではないコマンドレット名に手で書き直したために起こりましたw >>12 それだとうまくいきませんでした。(同じ結果が2回出力されてしまいます) >>12 あっ、すみません。勘違いでした。うまくいきました。 ただファイルの文字コードがSJISになってしまいました。 (元々ある「*.txt」のファイルの文字コードは全てUnicode) デフォルトがSJISなのでそうなる 必要なら-Encodingオプションに適切な文字コードを指定すれば良い >>19 なるほど!確かに文字コード指定してませんでした。 みなさん、質問ばかりでスレ汚しすみませんでした。ROMに戻ります。 COM経由でexcel操作するの楽しいな officeにコンソールが付いたみたいで新鮮 Office365でちょっと使う必要があって触り始めたのですが、 Get-MessageTraceDetail って言うコマンドレットのパラメータに「Event」ってのが あるんですが、このEventに指定できるパラメータを調べることは出来ますか? ヘルプを見ると、「Event パラメーターは、メッセージ イベント別にレポートをフィルター処理します。 以下は一般的なイベントの例です。」とあって、7個くらいパラメータ載っているですが、 そこに載っているパラメータでうまくフィルタが出来なくて困っています。 最近クリックゲームにはまっててパワーシェルでオートクリッカーを作ったわ デフォルトでskeyでオンオフ切り替え 連射の調整はstart-sleepを各自調整してください デスクトップで暴発するとかなりウザイんで移動する時注意 #auto Sheqel cliker beta # Default s key Toggle ON OFF $f = 0 $mode = $false $source = @" using System; using System.Runtime.InteropServices; public static class ascl{ const int MOUSEEVENTF_LEFTDOWN = 0x0002 ; const int MOUSEEVENTF_LEFTUP = 0x0004 ; [System.Runtime.InteropServices.DllImport("user32.dll")] private static extern int GetKeyState(int nVirtKey); [System.Runtime.InteropServices.DllImport("user32.dll")] static extern void mouse_event(int dwFlags, int dx, int dy, int cButtons, int dwExtraInfo); public static int keyhook(){ return GetKeyState((int) 0x53); } public static void lc(){ mouse_event(MOUSEEVENTF_LEFTDOWN, 0, 0, 0, 0); mouse_event(MOUSEEVENTF_LEFTUP, 0, 0, 0, 0); } } "@ #残り Add-Type -Language CSharp -TypeDefinition $Source while($true){ $f= [ascl]::keyhook() if($f -eq -127 -or $f -eq 1){ $mode = $true} else{ $mode = $false} if($mode){ [ascl]::lc() } start-sleep -m 3 } コード晒すならpastebinやgistを使えば? あとmouse_eventじゃなくてsendInput使うの推奨じゃなかったっけ? コマンドレット引数の文字列化規則がよくわからん 次の6、7番の改行が気持ち悪いのだが…… 1. echo a('b')c # => あれ、書き損じてるな 1. echo a('b')c # ⇒"a`nb`nc" 2. echo a('b') # ⇒"a`nb" 3. echo ('b')c # ⇒"b`nc" 4. echo a$('b')c # ⇒"abc" 5. echo a$('b') # ⇒"ab" 6. echo $('b')c # ⇒"b`nc" 7. echo $('b')c$('d') # ⇒"b`ncd" これはこういう解釈になってるわけ? 4. echo a$('b')c # ⇒ "a$('b')c" 5. echo a$('b') # ⇒ "a$('b')" 6. echo $('b')c # ⇒ "$('b')", "c" 7. echo $('b')c$('d') # ⇒ "$('b')", "c$('d')" おっと、カンマ(配列)じゃなくて空白でセパレートしてるのか gi $(1),2 ⇒ OK gi $(1)2 ⇒ 引数 '2' を受け入れる位置指定パラメーターが見つかりません uniqueってコマンドの正体なんだかわかりますか? Get-Uniqueと同じように使えるんでこいつのエイリアスかと思ったんだけど Get-AliasとかGet-Commandやっても見つからないんですよね。 >>30 なるほどGet-の省略なのか。 ありがとう。 PS C:\Users\bbb\Desktop> $h= @{ >> q="ssssss" >> e="ffffff" >> } >> PS C:\Users\bbb\Desktop> $h.GetType() IsPublic IsSerial Name BaseType -------- -------- ---- -------- True True Hashtable System.Object PS C:\Users\bbb\Desktop> $h["q"] ssssss これセミコロン要らんのな 最近気付いたわ まぁ便利と言えば便利だが色々謎仕様が多いわ それより日本語のHELPをさっさと作れよ ゴミ野郎が Get-EventLogで、-After オプションで日付指定すると、コマンドが終了までの レスポンスがとても悪いんだけど、画面に表示されないだけで全部取得してるのかな? Get-EventLog -LogName system -EntryType Error,Warning これは普通に早い Get-EventLog -LogName system -EntryType Error,Warning -After "2016/11/06 00:00:00" 11/06までのログは直ぐ出てくるけど、11/06まで表示すると少しの間止る。 100台程度のサーバのログを取りたいんだけど、日付指定すると遅すぎて どうしようか考え中。 何か解決方法ない? イベントログ取れるならGet-EventLogじゃなくてもいいってことならGet-WinEvent使うとか Get-WinEvent -FilterHashtable @{LogName='System'; level=2,3; StartTime='2016/11/6 00:00:00'} >>38 Get-WinEventをローカルで試したら早くて必要な情報も取れたからこれは良いと思って リモートのサーバに実行したら、動作が不安定というか。 1回目 RPC関係のエラー 2回目 普通にログを取得 てな感じで、ログが取れたり取れなかったりして、半日位いろいろしてみたけど俺には原因を 掴む事が出来んかった・・・。 Get-WmiObject経由で、イベントログ取ったらかなり高速に取れそうだわ。 時間がDMTF形式なのがちょっとめんどいけど。 > 8,4,3,9,11 -gt 6 8 9 11 > (8,4,3,9,11)[1] -gt 6 False > (8,4,3,9,11 -gt 6).GetType() IsPublic IsSerial Name BaseType -------- -------- ---- -------- True True Object[] System.Array 何が何でも独自色を出したいのか知らんが使いにくいわ ゴミ見たいな機能を付ける暇が有ったらヘルプファイルの翻訳でもやれよ 間抜け野郎が >>42 参考までに聞きたいんだけどarrayとintに比較演算子を使用した場合 どうなれば満足なの? >>42 何がしたいんだw カンマで配列になるのはかなり初期からの仕様だよ、「ゴミ見たいな機能」を新たに付けてるわけじゃないわな クラス構文とかだったらまだ分かるけど >>44 あの一々これに時間割いてやる暇は無いから こんなもんは単なる道具で利用価値がなきゃ放り投げるだけだからw これ使う人間がいい人なのを期待してるの?? まぁJ#と同じ惨めな運命を辿りそうだが よくわからないがエスパーすると… [n]を書き忘れるバグを作って調査に手こずり、文法エラーだったら即解決できたのにチクショウゴミ言語めと逆恨み、ってとこか? だとすると、間抜け野郎が、という自虐めいた〆が悲哀だな シェルスクリプト言語なら厳格さによるフェイルファストよりもシンタックスの手軽な多機能さを優先するのはおかしなことではないと思うが PowerShell ってシェルじゃないよねぇ... パワーシェル(シェルとは言っていない) 貴様がどんなにシェルスクリプトの座を狙おうと、Win+Xで起動するその日まではまだ認めんぞーとかそういう話? >>53 否定したいがための投稿だから 付き合う必要なし 凄く初歩的な事かもしれないけど、教えて下さい。 下記の用なxmlがあったとして、要素の指定に名前を指定しての アクセスはどうやってするのでしょうか? $xml = [xml](Get-Content c:\aaa.xml) $xml.products.product[0].list[0] <-listのoptionが全部表示される $xml.products.aaaa.1111 <-こんな感じに指定したら何も帰ってこない。 <products> <product name="aaaa"> <list type="1111"> <option>XXXXXXX</option> </list> <list type="2222"> <option>YYYYYYY</option> </list> </product> <product name="bbbb"> <list type="1111"> <option>XXXXXXX</option> </list> <list type="2222"> <option>YYYYYYY</option> </list> </product> </products> >>57 $xml.SelectNodes("//product[@name='aaaa']/list[@type='1111']") http://mtgpowershell.blogspot.jp/2010/07/xml.html PHPやRubyの代替として、PowerShell触り始めたが・・・ 代替にはならなそうな気がしてきた。 >>64 >>66 $Host.UI.WriteErrorLine('文字列') Write-Errorって終了しないエラーを投げるcmdletなんだろうね でthrowは終了するエラーを投げる >>68 リンク先の人が指摘している問題を確認できました? >>67 を書き込む前に、 $info = New-Object Diagnostics.ProcessStartInfo $info.FileName = 'powershell.exe' $info.Arguments = '-Command "$Host.UI.WriteErrorLine(''文字列'')"' $info.UseShellExecute = $false $info.RedirectStandardError = $true $process = [Diagnostics.Process]::Start($info) $process.StandardError.ReadLine() というコードで、プロセスの標準エラー出力に書き込まれるのを確認していました。 リンク先を読んで、 @echo off powershell.exe -NoProfile -Command "$Host.UI.WriteErrorLine('文字列')" 2> error.txt type error.txt というバッチファイルを実行してみましたけど、問題なく動きます。 リンク先の人は、どういうケースで問題になると指摘しているのでしょう? 分かったかも。 powershell.exe "[Console]::Out.WriteLine('文字列')" > out.txt 2> error.txt powershell.exe "[Console]::Error.WriteLine('文字列')" > out.txt 2> error.txt powershell.exe "$Host.UI.WriteErrorLine('文字列')" > out.txt 2> error.txt ここまでは、すべて期待通りに動きます。 powershell.exe "[Console]::Error.WriteLine('文字列')" > out.txt これも期待通りです。 powershell.exe "$Host.UI.WriteErrorLine('文字列')" > out.txt out.txt に「文字列」が書き込まれます。なんでやねん。 1> でリダイレクトしたら問題を回避できそうな気がする >>71 いま試したんですが、 "$Host.UI.WriteErrorLine('文字列')" の代わりに "Write-Error '文字列'" で表示させたり "1/0" でエラー出したりしても 同じ結果になりますね。 標準エラーは実体が想定されない出力ストリームなのに、 そこへ文字を赤くして出力してるHost.UI.WriteErrorLineの気持ち悪さ あけおめ! Stop-ProcessでFireFoxをシャットダウンさせてるんだけど 次回起動時に異常終了扱いになってセッションの復元を試みる画面が表示される。 普通にFireFoxのメニューから「終了」を選んだかのようにシャットダウンさせるのってスクリプトじゃ難しいですかね? >>76 どっかにそれやるサンプルスクリプトあったが、思い出せない 外部ツールだけどnircmd使うと楽だよ http://moon.gmobb.jp/renno/cgi/junk.cgi/computer/nir_cmd_command.htm#closeprocess 👀 Rock54: Caution(BBR-MD5:5549de2c873ac2edd146f280a5558991) しかしほんとにつかえーねゴミツールだなwww 非同期とか結局C#でやった方が早いし ガラクタの癖にやたら労力だけは要求するし あといつになったら日本語のヘルプを作るんだよ まぁオライリーの奴を向こうでかっぱらったから要らんけどさ Windows10でPushbulletを使ってるんですが通知を読み取る方法は無いでしょうか? 特定のメッセージを受け取ったら任意のコマンドを実行といった具合に使いたいのです ちとあぶないスプリクトを組んだんだが OSはWindows7 PowerShellはVer.2です。 http://pastebin.com/57quuSJi 理由はMVNOを変えた時不調で不審なアクティビティが検出され 強制的にPasswordを変更させられたのを元に戻す為。 で一応は動作したのだが不満な点がありまして $dom_userPWD1=$doc.getElementsByTagName("input") | Where-Object{$_.uniqueID -match "ms__id\d*[13579]\b"} inputタグで抽出したのをuniqueIDで識別したのですが処理毎に uniqueIDが変わって使いにくい、奇数と偶数で識別という トリッキーな手段で解決したのですが、 aria-labelの「新しいパスワード」・「新しいパスワード確認」 を使って識別する方法はありますでしょうか。 あと ($doc.getElementsByTagName("div") | Where-Object{$_.className -eq "O Ya rb pa"}).click() divで抽出してclassNameで目的のリンクを一致させてクリックさせているのですが divで抽出しているせいか処理に時間がかかってしまいます。 getElementsByClassNameが使えないかとやってみたが >[mshtml.HTMLDocumentClass] に 'getElementsByClassName' という名前のメソッドが含まれないため、メソッドの呼び出しに失敗しました。 と出てうまくいきません。 クラス名で一発で処理できる方法はありませんでしょうか。 >>82 「大型犬の死骸を溶かせる薬品有りませんか」って質問と同じ匂いがする >>84 querySelectorAllやってみたんですけどgetElementsByClassNameと 同じパターンでできず、やり方があるんだろうけどそこがわからず。 getElementsByClassNameももう一回やってみたけれどエラーは中身が 取り出せず断念、この場合PowerShellだけじゃなくてDOMや.NET Framework もからんでくるのでわけわかめ状態となっている。 試してないけどこんな感じになるんじゃないかな $doc.querySelector('div.O.Ya.rb.pa') ここの部分を ($doc.getElementsByTagName("div") | Where-Object{$_.className -eq "O Ya rb pa"}).click() >>86 を参考にして ($doc.querySelector('div.O.Ya.rb.pa')).click() 上記のように書き換えて実行してみたけど やはりメゾットがないと出てエラー どのオブジェクトで使えるのかとPowerShellで使えるのかが 問題、javaScriptは結構例があるんだけどね。 うーむ、うちのwin10だと動いたんだが こんな感じでわかる所から攻めてみたらどうだろう $doc.getElementById('view_container').firstChild.firstChild.children[2].children[1].firstChild (例によって試してないのであしからず) IE8以降のWin7なのにquerySelectorが使えないということはセキュリティー設定がらみでquirksでパースされてる可能性も しかし確かに怪しい臭いのする質問だな C:\hoge\hogehoge\hage.txt にあるファイルをドライブだけ変えて D:\hoge\hogehoge\hage.txt にコピーしたいのですが簡単な方法はありませんか? フォルダ部分の「D:\hoge\hogehoge\」は最初は存在しません $a = "C:\hoge\hogehoge\hage.txt" $b = "D:\hoge\hogehoge\hage.txt" Copy-Item $a $b とやるとパスの一部が見つかりませんといわれてしまいます 地道にSplit-Path -Parentでファイル名を取り除いた部分を得てからそのフォルダを New-Itemで作って、その後Copy-Itemするしかないんでしょうか? >>91 わからないのにいちいち口挟まなくていいよ ttps://www.google.co.jp/amp/tech.guitarrapc.com/entry/2014/08/12/081637%3Famp%3D1#amph=1 >>90 糞ダサだけどxcopyを使えば期待する動きになる xcopy c:\hoge.txt d:\a\b\c\d\e\f\g\hoge.txt Dドライブに\a\b\c\d\e\f\g\ が無ければ勝手に作ってくれる フォルダ作成するならこんな感じかな dir $b | % { md -Force $_.DirectoryName } xcopyは決してダサくないしむしろ最適解だと思う シンプルに外部コマンドを呼べることがPSの強みでもあるし >>95 細かいことだけど、dir〜のとこは Get-Item -LiteralPath $b が良いかと 入ってるのがもしフォルダ名だったらとか、もし[]が入ってたらとか不安になる >>97 馬鹿は黙ってろって言われてるのが理解できん? 無理にPowershellでやろうとする方がよっぽどの馬鹿だよ PowerShellで外部コマンドを実行する際、最初から優先度を指定して起動させる 方法はありませんか? 起動中のプロセスの優先度を変える方法はググググッていくつか例が見つかったんですが それだと一旦「優先度=通常」で起動して、即座に「優先度=低」に変更する、みたいな 感じになってしまうので最初から優先度低で起動したいです 自身(powershell)の優先度を下げちまえば良いんでね read.cgi ver 07.5.5 2024/06/08 Walang Kapalit ★ | Donguri System Team 5ちゃんねる