..◇・。..☆*。
゜゜・*:..。.。★◎@ ○☆。..:*・゜
゜゜・*:..。.。◇@☆*・゜★。。.:*・☆*・。..:*・゜
。..:○★◎☆。∂∇。★◎*・゜゜。◎★
◎☆◇☆。*・.。..☆◎。.:☆◇*.....。
゜゜・*:..。.*・☆◎。__☆◎*・。..:*・゜ ゜
\ /
\ /
. ∧_∧\ /
(´・ω・) ∞ >>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>
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のメニューから「終了」を選んだかのようにシャットダウンさせるのってスクリプトじゃ難しいですかね?
しかしほんとにつかえーねゴミツールだな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
わからないのにいちいち口挟まなくていいよ >>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)の優先度を下げちまえば良いんでね
ちょっとググったけど CreateProcess( ) を直接呼び出す以外の解決策は見つからなかった
ちょっと今試せる環境がないけど、Startコマンドを/LOWつけて実行するのは
なんか問題起きるっけ?
二重引用符の中で変数に格納したオブジェクトのプロパティを
展開する方法を誰か教えてくださいませんか
例えば
test.txtがあるディレクトリで下を実行
> $test = Get-ChildItem -Filter "test.txt"
$test.FullNameで絶対パスが見れる状態になると思うんだけど
Write-Hostで文字列の中に、このフルパスを埋め込もうとすると
上手くいきません
Write-Host "xxxx$test.FullNameyyyy"
とやると
xxxx$test.txt.FullNameyyyy
と表示されてしまいます
"xxxx$($test.FullName)yyyy"
>>105
> Write-Host "xxxx$($test.FullName)yyyy"
$( ) の中には文字列を返す式も書けるから結構便利 >>107,108
なるほど!
$()で囲めばいいんですね
ありがとうございました a.ps1とb.ps1という2つのスクリプトファイルがあって、b.ps1は1.pa1から
ドット演算子で呼び出しています。
----- a.ps1 ------
function main
{
. \b.ps1
}
こんな感じです
でもこれだとa.ps1で(mainで)定義した変数は全部b.ps1からも丸見えというのを
今日勉強しました。b.ps1から見えないようにするには変数をprivateで定義して
[String]$private:foo
こうすればいいというのは分かったんですがすべての変数にいちいちprivateを
つけるのはさすがに面倒というか億劫です
スクリプトファイルの先頭で "option private" みたいな感じで宣言したら
暗黙のデフォルトがlocalじゃなくてprivateになる、みたいな技はありません
でぢょうか?
例えば、変数の先頭にv_を付けるルールにしてスクリプトの最後で
Set-Variable v_* -Visibility private
てやるとか
別のファイルをインクルードするときにドットにした場合とアンドにした場合の
違いが分かりません。ドットにした場合は分かるんですが(単純にその場所に
展開されるだけ、という認識です)アンドにした場合は何が違うんでしょうか
MSDNの説明を見ても「現在のスコープを引き継ぎません」というなんともよく
分からない説明しか見つかりませんでした
>>113
> ドットソース演算子は、呼び出すスクリプトのスコープを拡大する記法
訳のわからん説明するなよ w
ドットソース記法は新しいスコープを作らないだけだぞ >>113
黙っていた方がマシなレベルの酷い説明だなw 最近C#を15年ぶりくらいに触りはじめたんだけど、
LINQのメソッド構文ってPowerShellのパイプラインみたいで面白いな。
どっちかが真似たのかな?それともループの直列化が時代の流れだったのか
最近になって必要にかられてパワーシェルしてるんですが、C#オブジェクトを
生成してC#と同じように使えるのでいろいろ出来てなかなか楽しいです
ところで漠然と質問で申し訳ないんですが、C#ネーティブで書いたバッチ処理に
比べてパワーシェルで「出来ない事」って何があるんでしょうか
無論どっちも.NETフレームワークは同じバージョンのものを使うという前提です
グラッヒックスやサウンド、ダイレクトXを使うようなアプリではなくいわゆる
業務用のバッチ(ファイルを読み書きしたりDBを読み書きしたり、といった)
ならパワーシェルに出来ない事はないようにも思えるんですが
MFCのメソッド呼ぶのに構造体渡しが必要な場合にパワーシェルだと構造体が
定義出来ないから呼べない位ですか?
win32は本来管轄外だしSystem.Net.WebSocketsなんかも厳しいかな
言語仕様上出来ない設計は結構あると思うけど、
add-typeで諸所のコード資産を統合的に活用出来るのがPSの本旨だと思う
>>116
PowerShellはgst-launch-1.0(GStreamer)がモロそんな感じだったよ
DISM /Online /Get-ProvisionedAppxPackages | select-string Packagename
みたいなのやん
gst-launch-1.0のは
gst-launch-1.0 filesrc location=music.ogg ! oggdemux ! vorbisdec ! audioconvert ! audioresample ! osssink
で、一番似てる気がしたのはコレ
WinAPI呼ぶときの魔法の文言が長すぎて鬱りそう、なんか短いのないのアレ orz 次スレからはソフトウェア板に移動しない?
MacとLinuxに対応したので
クリエにアップしたので、スタートボタン右クリックのメニューに入るのが
コマプロからPowerShellに変わったわけだが、エラーで開かないw
クラシック・シェル入れてたせいだろうな
すみません、どなたか教えてください。
管理者権限でpowershell実行
write-eventlog -logname 'Microsoft-Windows-TaskScheduler/Operational'
(-Source -entrytype -eventID -messageも指定)
でイベントログに出力したいのですが、
ログ名 "Microsoft-Windows-TaskScheduler/Operational" はコンピュータ localhostに存在しません
とエラーが出てしまいます。
Get-WinEvent -logname 'Microsoft-Windows-TaskScheduler/Operational'
ではちゃんと出力するので、ログ名を間違えていることはないと思うのですが・・・
原因を教えてくれませんでしょうか?
WMIはWindows固有だからなあ
PowerShellの文法的な話なら、プログラミング板が妥当では
これからWindowsCUIコマンド関連勉強していきたいんだけど
PowerShellの前にコマンドプロンプトも勉強した方がいい?
それとももう必要ない?
というかコマンドプロンプトとかいちいち時間割いて勉強するようなもんじゃない
>>125
> PowerShellの前にコマンドプロンプトも勉強した方がいい?
要らない
単にコマンドを連続して流すだけならずらずら書くだけだし
ちょっと凝ったことしようとしたらバッドノウハウ使いまくりになる
PowerShell も色々癖が強いけど後発だけに思想は遥かにまとも Powershellを使ってWindows7マシンからWindows10マシンを遠隔シャットダウンしようと思っています。
Windows7マシン名: PC1
Windows10マシン名: PC2
どちらのマシンにも同じユーザー名・パスワードの管理者権限のユーザーが作ってあります。
Windows7マシンからPowershellを管理者権限で起動し次のコマンドを打ってみました。
> Stop-Computer -ComputerName PC2 -Credential (ユーザー名)
すると以下の様なエラーが返ってきてシャットダウンできませんでした。
Stop-Computer : アクセスが拒否されました。 (HRESULT からの例外: 0x80070005 (E_ACCESSDENIED))
発生場所 行:1 文字:14
+ Stop-Computer <<<< -ComputerName PC2 -Credential (ユーザー名)
+ CategoryInfo : NotSpecified: (:) [Stop-Computer]、UnauthorizedAccessException
+ FullyQualifiedErrorId : System.UnauthorizedAccessException,Microsoft.PowerShell.Commands.StopComputerCommand
どちらのマシンもUACはデフォの状態から変えていませんし、
セキュリティのことを考えると変えたくもありません。
なにかいい解決方法は無いでしょうか?
>>125
オレも必要無いに一票
2つ勉強したいってならbashに一票
覚えた頃にBoWこなれてきてるかも >>129
挑戦してみましたがやはりエラーが返ってきました
Stop-Computer : RPC サーバーを利用できません。 (HRESULT からの例外: 0x800706BA)
発生場所 行:1 文字:14
+ Stop-Computer <<<< -ComputerName PC2 -Credential (ユーザー名)
+ CategoryInfo : InvalidOperation: (PC2:String) [Stop-Computer]、COMException
+ FullyQualifiedErrorId : StopComputerException,Microsoft.PowerShell.Commands.StopComputerCommand
ただエラーの内容がちょっと変わった気はします そのエラーコードならファイアウォール設定でWMI RPCを解放すれば行けそう
>>125
コマンドプロンプトなんか使ってるうちに覚えるもんだろ。
こんなところで聞くようなモノではない。 >>132
PC2のファイアーウォールを無効にしてみましたが結果は同じでした・・・
うーん、難しい・・・ >>128
ユーザー名の前に コンピュータ名\つけてる?
つまり、pc2\ユーザー名 >>135
はい、ユーザー認証のダイアログが表示される方式もチャレンジして
そこでコンピューター名付のユーザ名も試しましたがダメでした・・・ shutdownコマンドによるリモートシャットダウンはまだ試したことがありませんでした
一度チャレンジしてみようと思います
余談ですがリモートシャットダウンさせるさい、リモートレジストリ制御はオンにする
必要はありますか?Windows10ではデフォルトでオフにされているようですが。
0x800706BAで検索すると割と多くの原因が考えられるみたい
互いのPCで関連サービスが全部起動してるかとか、パッチが当たってるかとか
てす
Function set-oepic{
[CmdletBinding()]
param(
[Parameter(Mandatory=$True,
ValueFromPipeline=$True)]
[string]$picpath
)
PROCESS {
$bin = Get-Content $picpath -Encoding Byte
$base64 = [System.Convert]::ToBase64String( $bin )
$pics =@"
var canvas = document.getElementsByClassName( "wPaint-canvas" );
var ctx = canvas[0].getContext("2d");
ctx.fillStyle = "white";
ctx.fillRect(0, 0, 500, 250);
var img = new Image();
img.onload = function() {
ctx.drawImage(img, 0, 0);
}
img.src = "data:image/png;base64,$base64";
"@
Set-Clipboard -Value $pics
}
END {}
}
>>141は>>140の貼り付けスクリプトねたぶんクロム系で動くはず
説明する必要はないと思うが 引数に500X250の128k以下の画像のファイルのパスを入れて
実行するとクリップボードにソースが貼り付けられるから
今度はスレッドのお絵描きロードを押してフォームを出した後でf12でコンソールをだして張り付けて一回リターンを押せば
フォームに画像が貼り付けられてると思う
個人的にアクセス規制見たいの食らってるのか知らんが 上の5.7kの画像でようやくアップロードできた
興味のある人は100k程度のを張ってみてくれ 3日前ぐらいまでは貼れたんだが
何時も使ってるサイトが使えんのでpsで書いてみた そういやbase64にエンコとかするコマンドレットってあるの?
会社のwin7ノートでstaticとDHCPをダブルクリックで切り替えたくてバッチファイルを作ったんです
しかし世間はPOWER SHELLに移行すると知り、この際書き直そうと思い早速get-netadapterを叩いてみました
が、出鼻を挫かれました
操作可能なプログラムとして認識されません。が返ってくるだけで受付てくれません
ポリシーでブロックされているんでしょうか
>>145
ちゃんとPowerShellのプロンプト画面で叩いているんですか?
>操作可能なプログラムとして認識されません。
PowerShellのコマンドですから、プログラムを起動しに行くはずはないのですがね Windows10起動時に出る謎窓?
>>147
それ、タスクスケジューラからOffice関連の更新の何かが起動されていそうですよ >>145
get-netadapter は PowerShell Version 3 以上でないと使えない
Windows 7 の PowerShell は Version 2 なので PowerShell をバージョンアップするなり Windows 10 に行くなりしてくれ
あとエラーメッセージはコピペでいいので正確に書いてくれ >>145
Win7でやったらこんなん出ました
PS C:\Windows\system32> get-netadapter
get-netadapter : 用語 'get-netadapter' は、コマンドレット、関数、スクリプト フ
ァイル、または操作可能なプログラムの名前として認識されません。名前が正しく記述
されていることを確認し、パスが含まれている場合はそのパスが正しいことを確認して
から、再試行してください。
発生場所 行:1 文字:1
+ get-netadapter
+ ~~~~~~~~~~~~~~
+ CategoryInfo : ObjectNotFound: (get-netadapter:String) [], Comm
andNotFoundException
+ FullyQualifiedErrorId : CommandNotFoundException そろそろうぜぇ
セーフモードの入り方の解説なんかググれば出てくるものをそこら中に貼らんで良い
コマンドプロンプトってWindows7と10で劇的な違いとかってあった?
技術評論社のポケットリファレンスを買おうと思ってるんだけど、7の時に出たのは1000円程で10対応の最新版は3000円超えなんだよね
仕事でゴリゴリ使う訳じゃないから確認用に持っときたい程度
コマンドプロントからできる程度の作業ならもう全部pshell使ってるなあ
つまりもうコマンドを使う機械自体が絶無
>>156
でも結局パワーシェルなんかだれも使わんでしょ
ぼくら見たいな大して役にも立たないものに労力を費やしてくれるいい人以外はw
unityでlinqを使いましょうとか声を張り上げてたあふぉを思い出したww >>158
おまそうwwwwww
とくれさwwwwww PowerShell関連の書籍で今現在評判いいのがポケットリファレンスしかない
>>160
To:
[email protected]
Cc:
[email protected]
松本殿、元上司が「ヒロシを守るため」と激白した映像が公開されていますが、認識はありますか?
「人事に言われた」とも言っていますがこれはウソですか?
ウソなら訴えて訴えて動画を削除させるべきではないのですか?
2017/05/12(金) 21:42
松本淳殿、パワハラやセクハラの被害者に謝罪しましたか?
なぜ謝罪しないのですか?
パワハラセクハラの調査という名目で事実が無いという工作行為に加担するように脅迫したのはなぜですか?
知らなかったと言うように脅迫したのはなぜですか?
ネットに聴取された人が流したと思われる録音が出回っているのはガセとでもいうのですか?
その脅迫して言わせたヤラセを元に、裁判で虚偽の申告をしたというのは本当ですか?
当社を偽証罪の渦に貶めるつもりですか?
幻聴の可能性があると言いたいのですか?
パワハラ加害者にも問題はありますが、貴殿は人事としての監督責任すら持たない、
単なる会社のお客さんとでも言いたいのですか?
マイクロソフトの人事はマネージャーをサポートするのが仕事で不正を守るのが当たり前の文化だ、
告発を認めないとはどういうことですか?当社のマネージメントは不正に対し自制もできない、
世間に顔向けできないばかりか、みっともなく情け無い体面の者の集団とで言いたいのですか?
どこの部署のマネージメントの発言か5W1Hで摘示ください。 PowerShellからファイル名を置換するコマンド
Get-ChildItem "フォルダパス" | Rename-Item -NewName { $_.Name -replace ' ','' }
これ面倒なことしなくていいので便利なんだよね
replaceの第二引数にスクリプトブロック渡せればもっといいんだけどな
書籍見てるとパイプを多用するようなんだが
そうせんと文句言われたりするもんか? (宗教争いが面倒、くらいの意味)
function print_test($a) {
Write-Host $a
}
print_test "a", "b", "c", "d"
------------------
PS C:\Users\test_user\Desktop>> .\win10_policy.ps1
a b c d
この挙動の謎っぷりマジ謎……
functionの引数では , いるけど呼び出し時は , いらんとかよく間違える
その辺なんとかならんかなぁ
PSのカンマは配列を作るって覚えりゃいい
この二つは同じ
print_test "a", "b", "c", "d"
print_test @("a", "b", "c", "d")
pshell使っててWINDOWSのエラーハンドル?が返って来た場合のエラーコード取得って
どうやってやるのが定番でしょうか?
例えばファイルを書き込もうとしてDISC-FULLのエラーになった場合ってエラーコードとしては
0x80xxxx03みたいなコードが返ってきますけど必要なのは下位1ワードだけなんです
>>169
たまにしか触らんせいだろうが、細かい部分でどうでもいいエラーが出るので
やっかいだなーという程度
String.equals と -eq で挙動違うのと
foreach-objectでループ二段抜けと
関数呼び出し時の , 有無は俺にはよくある orz
細部の表記に統一性もたしてくれたらPowershellイケてるよね、って言いきれるんだが
なかなか難しいところか function set_registry_entry($key, $entry, $type, $value) {
set_full_registry_key $key
New-ItemProperty -Path $key -Name $entry -PropertyType $type -Value $value -Force
}
function set_full_registry_key($key) {
if (-Not (test-path $key)) {
$parent = Split-Path $key -Parent
Write-Host $parent
if (-Not (test-path $parent)) {
set_full_registry_key $parent
}
New-Item -Path $key
}
}
set_registry_entry "HKLM:\SOFTWARE\Policies\Microsoft\Windows\WindowsUpdate\AU" "AUOptions" "DWord" 3
set_registry_entry "HKLM:\SOFTWARE\Policies\Microsoft\Windows\WindowsUpdate\AU" "NoAutoRebootWithLoggedOnUsers" "DWord" 1
Powershellらしからぬ気もするが、パイプを意図的に使っていかないとPowershellぽくなくてダメなんだろうか?
>>173
あくまで自分の趣味だけど、パイプ多用で書き直してみた
この方が関数名や変数名考える必要もないし、名前のミスも少なくてよいと思う
でも関数でやるのが体に染みついてるならその方が楽だろうし、好き好きでいいかと
%{
@{
Path = "HKLM:\SOFTWARE\Policies\Microsoft\Windows\WindowsUpdate\AU"
Name = "AUOptions"
PropertyType = "DWord"
Value = 3
}
#二つ目は省略
}|%{
$key = $_.Path|Split-Path -Parent
%{
while(-Not (test-path $key)){
$key
$key = $key|Split-Path -Parent
}
}|sort -Descending|%{
Write-Host $_
New-Item -Path $_
}
New-ItemProperty @_ -Force
} 二カ所間違えてた
やっぱテストしないとダメだな
%{
@{
Path = "HKLM:\SOFTWARE\Policies\Microsoft\Windows\WindowsUpdate\AU"
Name = "AUOptions"
PropertyType = "DWord"
value = 3
}
#二つ目は省略
}|%{
$key = $_.Path
%{
while(-Not (test-path $key)){
$key
$key = $key|Split-Path -Parent
}
}|sort|%{
Write-Host $_
New-Item -Path $_
}
New-ItemProperty @_ -Force
}
>>174
鬼かwwww
まあ文句言われないようなら関数でもいっか……d うげ、また確認用Write-Hostがのこってるとか
うんもういいうや……
Win7デフォルト + PowerShell + UI Automationだとコケる可能性あるな
ボタンだかのメソッドを引っ張ってくる「なんちゃらPattern」が何も返さないっぽい
ぽいってのは全パターン網羅やってない、くらいの意味だが
列挙系のメソッドぶっこんだら空でしたって悲しい話(Write-Hostで戻り値みたら何もでなかった、くらいの意味で
Excel の表をソートする方法はありますか。
範囲A1:K8 の表の、D2 の列を昇順にソートしたいのです。
poweshellって結構なんでもできそうな感じがするんだけど、もしかしてDirectXのDDSファイルの情報とかも取れたりするのか?
DDSファイルの情報を取得して返すプログラムを書く
↓
そのプログラムをPowerShellから呼ぶ
で、できるんじゃないの
>>186
馬鹿が一々口出してこ無くていいよ
そんなに構って欲しいの?構ってチャン >>185
DDSファイルの情報が何者か知らんけどファイル内に情報あるなら取得できるでしょ 偉い人アドバイスをお願いします。↓のブログを見つけて携帯にグローバルIPアドレスの変更を通知しようと考えまして、
旧アドレスを記載したテキストを参照するところまでは記述の意味を何とか理解できたのですが、
「レスポンスの読み込み&確認」以降がどうしても良くわかりません。
http://rtaki.blogspot.jp/2010/10/ip.html
サイト(http://www.axisnetworks.biz/tools/gip/)のソースを見てみると、グローバルIPアドレスの直前に「<p class="style4" name="ip">」がありますので、
「$line」が空でなければ、そこにこれが含まれているかチェックして、次に何かとの一致があるかを確認しているようですが、
この「(?<address>[0-9]+\.[0-9]+\.[0-9]+\.[0-9]+)」が何を意味しているのか分からないです。
また、「$new address」は「$matches.address」だと定義され、それが変更時には上書き動作に引き継がれているようですが、
その「$new addredd」がどこから来るのかが分かりません。
なお、Write-Outputについては、2つ目の「前回確認済みのグローバルIPアドレス:」までは表示できています。 正規表現でIPアドレスっぽいパターンを持った文字列を検索して、見つかったらその部分にaddressという名前を付けてる
$new addressではなく$new_addressな
どこから来るとかではなく、新しい変数をここで初めて宣言して代入してるだけ
$matchesの方がどこから来たかというと、-match演算子の結果が格納される暗黙変数として決められてる
どっちのifでどう失敗してるかとか、Write-outputをいろんな行に入れて、いろいろな値や式を渡して模索してみるといいと思うよ
>>190
なかなか新鮮な質問だねw
(?<address>[0-9]+\.[0-9]+\.[0-9]+\.[0-9]+)
は正規表現で、数字の連続、点、数字の連続、点、数字の連続、点、数字の連続 にマッチする。要するにIPアドレスっぽい部分
?<address>はマッチした文字を入れる変数名の指定。$Matches.addresという書き方で参照できて分かりやすいねという話
$new_address = $matches.address は単純な代入式だw $new_addressという変数に$matches.addressの値を入れてるだけ
昔言語の先生の、「プログラムの=はイコールじゃない。結果的に同じになるけど」ってセリフ思い出したw >>194
` はPowerShellのエスケープ
RegularExpressionはPowerShell専用じゃないので\をエスケープに使ってる
ちょっと戸惑うけどそう言うものだと思うしかない かつてWSHが捨てられたように、今度はPSが捨てられる序章ってこと?
100枚ほどある連番画像を保存したくプログラミングの知識もない自分が
独学で下記のようなスクリプトを書きました
目的は果たせたのですがこういう風に書いた方がいいとかの意見が頂けると助かります
画像URL
""から
""まで
スクリプト
$Dir = ".\IMG\EvaR24_"
for ($i=1; $i -le 100; $i++){
$Source = "http://modelblog.org/wp-content/uploads/2017/05/EvaR24_" + $i.ToString("000") + ".jpg"
$Dest = $Dir + $i.ToString("000") + ".jpg"
Invoke-WebRequest -Uri $Source -OutFile $Dest
}
Pause >>202
ありがとうございます。
こんなナイスな書き方あるとは想像も付きませんでした。
どうして@hashが
-OutFile: ファイルパス -Uri: 画像URL
みたいな感じで展開されるのかも未だ理解出来てないのですが
調べながら理解を深めたいと思います >>203
@ で展開されるとか、まあそういうもんだと思うしかないね
利点は別の変数用意する必要ないからミスが減る >>204
>>205
スプラッティングと言うんですね リンクありがとうございます
ためになります
>>206
便利な機能だと思うのでそういうもんだと思って受け容れたいと思います
>>207
まさにそういうことでファイル名の一部です
自分でも$Dirなんて名前の変数に含めるのはちょっとおかしいかな?
と思いつつ手抜きしてた部分だったのでお恥ずかしい限りです
みなさんありがとうございます 質問させてください。
@:ADからユーザーIDを基にメールアドレスを引っ張ってくる
A:@の処理を数百単位のユーザー分一気に行い、ファイル(txt、csv等)に出力
↑の2点をやる必要があり方法を調べているとどうも@はpowershellでできそうだ、と
詳細を調べて以下の形でメールアドレスを引っ張り、csvに出力すること自体はできました。
get-aduser -filter {Name -like "ユーザー名"} -Property EmailAddress | Select-Object EmailAddress | Export-csv -path パスとファイル名.csv -NoTypeInformation
ですが、出力された結果は
EmailAddress
[email protected]
と2行になっていました。
これを2行目(メールアドレスだけ)出力する方法はないでしょうか。
また、Aについて、あらかじめ用意したユーザーIDが記載されたファイルのインポートややコピペで一気にメールアドレスを
出力する方法はないでしょうか。
よろしくお願いします >>211
csvの形式は最初にヘッダ行が必要だから、それが正常な出力だよ
アドレスだけにしたいならこれでいい
get-aduser 略|%{$_.EmailAddress}|out-file パスとファイル名.txt
あとユーザー名のリストでやるならこうかな
Get-Content ユーザーIDが記載されたファイル|%{get-aduser -filter {Name -like $_} -Property EmailAddress }| 略
やっつけで処理遅そうだけど スクリプトを覚える動機は何時だってエロ画像ダウンローダなんだな。
わざわざVSを立ち上げてプロジェを作るほどじゃないけど、だからと言って
いまさらbatchを使う気にもなれない
と言う理由でpshを使ってる
>>212
ありがとうございます。お礼遅くなってすいません。
教えていただいたやり方で一斉にメールアドレスを取得できる事を確認できました。
Powershellなんて使った事もない人間に無茶振りする上司が悪いので、もっさりでも
「こんなもんですよ」で通しますw $付きの環境変数があるんだけど、変数名の前にenv:付けても取れない。
この場合どうせればよいかのぅ。
引用符をシングルクォートに変える
それでもダメならアクサングラーブでエスケープするとか
>>217
明日やってみます!ありがとう!
結果も報告いたしますね! >>217
あれ。。こんな感じですか?
環境変数 $aaa
$bbb='$env:aaa'
echo $bbb
変数bbbに、環境変数$aaaが代入される それだと単にaaaという環境変数を求める書き方になってる
ちょっと試してみた
get-item 'env:$aaa'
get-item env:'$aaa'
get-item env:`$aaa
どれでも値を取り出せる
echo等に直接渡すために上記の先頭に$を付けると{}で囲んでみろよという親切な警告が出るね
{}で囲むならシンプルにecho ${env:$aaa}でOKだったわ
>>220
取れました!取れました!取れました!取れました!
ありがとおおおおおおおおおおおおおおおおおおおおおおおおございます!! 先輩方お世話になります
PowerShellではIEやExcelについては、内部情報がわかっているのでセル内の数値を読みだしたり、
IEでWeb上のデータをExcelに読み出したりできますが、
知らないソフトを操作することはできるのでしょうか。
パスワード管理ソフトがそこにあった場合、それを自動で操作できるものでしょうか。
>>224
それを見て安心しました。
PowerShellを本格的に使います。
ありがとうございました。 引数で渡されたcsvヘッダーなしファイルを、
1レコードづつ分割して、
各レコード中の5番目の項目をファイル名にしたく
色々調べて何となくパワーシェルでできそうかもと感じたのですが、
パワーシェルでは難しいものでしょうか
>>226
PowerShell csv
とかでググることもしない君には無理かも 使い始めて半年になるけど、コマンドプロンプトよか遥かにマシだけど、MSのスクリプト言語はやっぱうんこだね
>>232
あなたの考えるうんこでないスクリプト言語は何? >>232
理由を説明することが出来ず結果だけ述べるやつは頭蓋骨の中にウンコが詰まってるらしいね 負荷テストのために下記コードを書いて見ましたがこれって音は全部鳴ってるのかな?
# 下記サイトより効果音をお借りしました。
# http://maoudamashii.jokersounds.com/archives/se_maoudamashii_explosion06.html
# d:\indexフォルダは好きなように変更してください。
$loopcont = 128
$list = New-Object 'System.Collections.Generic.List[System.Media.SoundPlayer]'
for ($i=0; $i -lt $loopcont; $i++){
$a = New-Object Media.SoundPlayer("d:\Index\se_maoudamashii_explosion06.wav")
$list.Add($a)
#$list[$i] = New-Object Media.SoundPlayer("d:\Index\se_maoudamashii_explosion06.wav")
Write-Output "サウンド $i を追加しました。"
}
for ($i=0; $i -lt $loopcont; $i++){
$list[$i].PlayLooping()
Write-Output "サウンド $i を再生しました。"
Start-Sleep -m 10
}
Start-Sleep -s 15
for ($i=0; $i -lt $loopcont; $i++){
$list[$i].Stop()
Write-Output "サウンド $i を停止しました。"
}
Start-Sleep -s 5 プログラムスレ行きます
>>235は取り下げします UI Automation Extensionで#32770のダイアログを取得してくれないのってどう対応すればいいんでしょうか
UIAutomationSpyで見る限り取得先は間違ってないんですが、Sleep入れたりしても改善しません
>>226
練習のつもりでそれやってみた。私がやったのはこんな感じ。
もっといい方法あるんでしょうけど。
$lines=get-content c:\Test.csv
$head=($lines[4].Split(",")).ForEach({$_})
$data=($lines|ConvertFrom-Csv -Header $head)[0..3+5..($lines.Length-1)] テキスト変換ならawkも楽しい
gawk -F ',' -- '{print>>$5}' %1
あ〜〜〜、
私、問題を取り違えてる
5列めをファイル名にすんのね。
5行目をラベルにすると勘違い。
またトライしてみよう。
ごめん、いまの226じゃなく238ね、
何度も申し訳ない。
こんな感じかな。
ファイル名にして、中身を何にするのかわからないんで
単に5列めを取り出しただけだけになるけど
$lines=Get-Content c:\test csv -Encoding Default
$lines|%{$_.Split(",")[5]}
同じことを短く書くとこうかな
(Get-Content C:\Test.csv).Foreach({$_.Split(",")[5]})
さらに短くすると、こんな感じかな
(GC C:\test.csv).foreach({$_.Split(",")[5]})
PowerShellって
他のスクリプトに比べると可読性がいいね
>>244
cat C:\test.csv | %{$_.Split(",")[5]}
とか?
Get-Content はcatと書きたい派 まあ、ヘッダーがないなら付けた方がいいよね。
単純に「,」で分割しちゃうとエスケープされた,が入っている時に困る
cat C:\test.csv | ConvertFrom-Csv -Header @('a', 'b', 'c', 'd', 'filename') | %{$_.filename}
パイプ経由だったら
cat C:\test.csv|Select ({$_.split(",")[5]})
の方が速いかもしれない
>>239以外は5列目を取り出すというスクリプトにしかなってない
エクササイズにしたってそれでいいの?
質問者の「ファイル名にしたい」というキーワードは、行ごとに個別ファイルに分割出力したいってことと考えるのが自然
いろいろ調べてパワーシェルでできそうかも?パワーシェルでは難しいですか?って疑問ともよりマッチする
質問者の言葉足らずも、プログラマのできる範囲ややってみたいことも「顧客が本当に必要だったもの」っていうブランコの風刺絵を連想させるゾ ファイル名にしたいっていうのが良く分からんかったからスルーしてたわ。
とりあえず、csvの5列目の値をファイル名にもつ、空ファイルを作るならこんな感じかな?
(動かしてないけど)
cat C:\test.csv | ConvertFrom-Csv -Header @('a', 'b', 'c', 'd', 'filename') | %{eco "" > $_.filename}
$path = 'C:\test.csv'
gc $path | % {sc (ConvertFrom-Csv $_ -h (1..5)).(5) $_}
別に質問スレじゃないから、古い質問をダシに遊んでたっていいんじゃね?
出力ファイルの内容を何にするのか意味がとれなかったよ。
その行ということなんだな。こんなやり方にしてみた。
GC C:\test.csv|%{out-file -i $_ -fi $($_.Split(",")[0]+".csv")}
あ、配列のインデックス間違った
0 じゃなく 4 ですね。
powershellのバグ発見しちゃったんですけど。
chdir "test.txt" 2> clip
ってやってもエラー出力がクリップボードにコピーされません。
chdir "test.txt" 2>&1 | clip
ってやったらできました。
バグなんて言ってすいませんでした、powershellさん。
gc aaa.txt
↑のコマンドでaaa.txtの中身を表示できますが、この時に
1行目
2行目
3行目
4行目
5行目
と行順に表示するのではなく
3行目
2行目
5行目
1行目
4行目
のようにランダムに表示することはできるのでしょうか?
$txt = gc aaa.txt
random $txt -c $txt.Length
>>257
返信遅れてすみません。
うまく出来ました。ありがとうございます!
randomってかなり初期バージョンのPowerShellですら使えるんですね。存在すら知りませんでした(^_^;) powershellすごく便利よね。これなんで流行らないの・・・。
>>263
頭の良い人にしか使いこなせない
使いはじめるハードルも高い 裏方だけど十分流行ってると思うよ。
MSのサーバー系の管理はほとんどPowerShellに置き換わってるし
Azureの管理もPowerShellが主流。
Win10でもちょっと探ってみれば随所で使われてる。
MS系のシステム管理者はだいたい大なり小なり使ってるんでは。
ちょっとしたBootstrapperとかもそうやね
>>263
とっつきにくいんだよねw
自分も最初はCMDと行ったり来たりしてた。
今は慣れちゃったからCMDと使い分けてるよ。
SQLのハンドブックでSqlServerやOracleの構文が併記されてる書籍があるけど
同じようにCMDとPowershellを併記した書籍なりサイトがあれば初心者も入りやすいかもね。 ☆ 私たち日本人の、日本国憲法を改正しましょう。現在、
衆議員と参議院の両院で、改憲議員が3分の2を超えております。
『憲法改正国民投票法』、でググってみてください。国会の発議は
すでに可能です。平和は勝ち取るものです。お願い致します。☆☆
――――
6.0.1入れてみた、起動や動作がかなり早くなってる
標準のエンコードがUTF8になったようで、今までshiftjis扱うには-encode defaultで済んでたのが -encode oemに
あと.ps1ソースがshitjisだと文字化けする
ついでにテスト環境がいまいち、ISEでは使えないし
vscodeも(出来るとは思うけど)設定がよく分からない。F5のデバッグだと自動で5.01が立ち上がる
まあwin7に5.0.1とか入れるくらいなら6.0がいいかもね
'a'..'z' が 'a' から 'z' までの文字を返すようになったらしいので
'あ'..'こ' ってやってみたら予想外の結果が返って来たw
いろは順って言ったら"い".."と" で「いろはにほへと」でしょw
JISコードの順番だね、"ぁ".."ん"でひらがな全部出てくる
これ考えた人天才だな。1文字も重複せずにストーリーにしちゃうなんて。
「いろはにほへと ちりぬるを わかよたれそ つねならむ うゐのおくやま けふこえて あさきゆめみし ゑひもせすん」
↓
「色は匂へど 散りぬるを 我が世誰そ 常ならむ 有為の奥山 今日越えて 浅き夢見じ 酔ひもせず」
>>279
確かにw
コーディングでこれ書いてるとこ見られたら勘違いされそうw とあるフォルダ配下にあるテキストファイルだけ抽出して配列に格納
別のフォルダ配下にあるテキストファイルだけ抽出して配列に格納し配列同士を比較して同じファイルのみを抜き出してCompare-Objectで比較したいんですけどどうやったらできますか?
すみません↑書き込む場所間違えたのでプログラム板行きます
任意のディレクトリ内の全てのファイルに対して、ファイルプロパティに任意の文字列が含まれているファイルのフルパスを取得したいのですが。
賢い方、よかったらコード下さい。
具体的には、ファイルプロパティの詳細、バージョン情報で検索をかけたいです。
>>286
レスありがとうございます。
やっぱり時間かかりそうですね。 昔、powershellでexcelのデータ扱えるかなと思って試して見たが、目で追えるほど処理が遅かった。
excelのVBAの方が余程使える気がするが、powershellでそういった処理してる人って居る?
コードが無いから何とも言えんけど工夫次第かな
それより目で追えるのはScreenUpdating関係では無く?
既存のrtfファイルを「Microsoft Print to PDF」を使ってPDFにしたいと考えています
(Wordから直接PDFとして保存すると何故かrtf中の画像が粗くなり、「Microsoft Print to PDF」で印刷したら問題が回避できたため。マシンにはAdobeはreader以外インストールされておらず)。
Start-Processでやろうとしたものの出力ファイルの指定がわからず、そこで止まっています。
印刷ができればStart-Processに拘らないのですが、ご存知の方がいればご教示いただけないでしょうか。
screenupdatingは関係ないと思う。そう言う次元ですらないから。
1セル1秒みたいに時間がかかる。
Windows10のISEは標準で日本語だけど、
Windows7のアップデートでいれたISE5.1は英語になってる
日本語化できる?
>>289
>昔、powershellでexcelのデータ扱えるかなと思って試して見たが、
>目で追えるほど処理が遅かった。
一つ一つセルごとに出力したら遅いよ。
配列にいれて処理すれば一発。 >>289
別にお勧めしないけど、私は使ってるよ。
遅いのは処理の仕方の問題で、>>294 に書いたような処理をすれば早い。
難しくもない。
単純な表形式なら、プログラムでクリップボード利用すると
一瞬で処理がおわる。 Excelアプリを操作するより、XLSXファイルを操作する方が何かといいね
友達から教えてもらった簡単確実稼げる秘密の方法
関心がある人だけ見てください。
グーグルで検索するといいかも『金持ちになりたい 鎌野介メソッド』
YJL2J
友達から教えてもらったネットで稼げる情報とか
興味がある人はどうぞ
グーグルで検索するといいかも『ネットで稼ぐ方法 モニアレフヌノ』
ADP78
Invoke-ItemでPDFを開くことはできたのですが開くページの指定はできないですか?
関連付けられてるソフトはSumatraPDFですが,ページ指定して開けるなら他のソフトでもいいです
OSはWin7でPowershellは5.1.14409.1012でした
そんなこと聞いてきてしまうレベルの人にあう本はないだろうね
それは定番が既にあるという意味なのか、ネットのチュートリアルで充分or僕は本嫌いだからお前らも読むなという意味なのか、amazon評価を鵜呑みにせよという意味なのか
どんな本を読んだところで理解できまいという意味だろ
定番を知ってるなら無いという回答と矛盾するし
詳しい人のほとんどは本を買ってないから大型書店かネットで試し読みが早くて確実なんじゃないか
実行ファイルの右クリックのプロパティーの「管理者としてこのプログラムを実行する」を
コマンドラインからチェック入れる方法ってあるかな
ソフトのセットアップ時に毎回設定するのがかったるくなった
>>308
コマンドからだけでなく、exeダブルクリックでも.lnkからでも管理者権限にしたい
307の設定がOSのどこかには格納されてるはずなんで、それをコマンドで変更したいんだけど、無理かな
レジストリのどこかかね 使わなそうなexe(既存のをコピーして名前変えても拾ってきてもいい)でチェック入れて
regeditで検索すればすぐ見つかるよ
>>310
見つけた!
なるほど、この手があったか、ありがとう ExcelでA1:A3に
佐藤 なんちゃら
田中 なにがし
高橋 えみった
と書いているとして、
$tanto = 高橋
と部分一致したA3の値をB3に書くにはどうしたらいいですか
>>307
俺ならUACを一時的に無効にしちまってからインストール作業をするけど、
管理者権限の許可タブをクリックするだけの作業なんてダルくも何ともないです >>313
複数のアプリでセットアップ対象も複数なら自動化したくもなる >>312
pwsh内で配列とかで処理するようだけど、現段階で使い方が理解できませんでした
Excelに$tantoを書いて、Excel内でvlookupした結果をまた$tantoに格納してExcelに戻す
というまったくスマートじゃない方法でひとまず解決しました >>285-286
便乗質問ですけど、任意のディレクトリ内の複数のpdfについて、pdfを開いてから見られるプロパティのフォント(の埋め込み)情報をまとめて取得したいと思ってます。
そのようなコードあったら教えてもらえませんか? Rename-Itemで角括弧入りのパスを扱うときは-Literalpathをつけるといいってのは調べるとすぐにわかったんだけど、
角括弧入りの名前を付けたいときはどうすればいいの?
録画ソフトでとった番組ファイルをスクリプトで圧縮するときに、一旦仮の名前にリネームしてから圧縮後のファイルに後で戻したいんだけど
番組名によってはエラーになってしまうんで困った。
普通に付けられたけど
Get-Item .\てすと.txt|Rename-Item -NewName [てすと].txt
>318
ごめん、確かにできるね。
"?"のほうがいかんかったみたい。
"?"がまたどうにもならんね。
>>319
?は*と同じくファイル名には付けられないよ
dos時代からね >>320
なるほど!
すっきりしたよ。ありがとう ROBOCOPY /MIRの動作をPowerShellで簡単に実現できますか?
ROBOCOPYコマンドを起動した方が良いですか?
grepやless、viなんかに相当するコマンドって追加された?
以前触った印象だとpowershell割りと嫌いじゃないんだけど、
CLIで完結できますみたいな方向性じゃないのか今一歩使えない
あくまでインタフェースの提供って位置付けなのかな
慣れたものが一番。
それ以上の発展性はないけど、単純に文字列として扱うだけならgrepでいいと思う。
餅は餅屋かな。
>>325
この板にあったwshスレの後継だし
全然プログラミングやらない人のためにも必要 まあ、神奈川県があれば静岡県もある、でも合併しない。
共産党があれば立憲民主党もある、でも合併しない。
立正佼成会があれば創価学会もある、でも合併しない。
幼稚園があれば保育園もある、たまに合併する。
そんなものと思えば。
>>325
そもそも、あちらが過疎ってたせいでこっちに来た私に謝罪を要求します ./hoge.ps1
powershell -command ./hoge.ps1
上の二種類の起動方法を、hoge.ps1自身の処理において識別することって出来ない?
>>334
自分のプロセスのコマンドラインを調べるとか。
Get-WmiObject Win32_Process CommandLine -Filter ProcessId=$PID powershellからsshできるようになったけど、これって前からだったっけ?
PSVersion 5.1.17763.134
前までできなかった気がしたけど、いつのまにできるようになってたのね
見てて思ったけど同じps1ファイルを複数実行してるかどうかを把握する方法ってないのかな
コンソール別になるとわかんなくない?
二重起動禁止する方法無いか調べて見つけられなくてMutex使った思い出。
mutexはリリースを忘れてしまうか、スクリプトがリリース前に中断すると
コンソール閉じない限り状態が保持されてしまわない?
泥臭いけど特定パスに排他用のファイルを書き出すという手もある
レジストリでもなんでも排他したい範囲でユニークなリソースを使えば大抵の言語でできる
有効期限等を書き出しておけばロック掛かりっぱなしのトラブルも避けられる
こんなんでよいのでは
if(Test-Path .\myprocess.pid){
$check_pid = (Get-Content .\myprocess.pid).Trim()
if(Get-Process -Id $check_pid -ErrorAction SilentlyContinue){ exit }
}
Out-File -InputObject $PID -FilePath .\myprocess.pid -Encoding default
Start-Sleep 10
Remove-Item .\myprocess.pid -Force
排他ロックファイルは最悪予期しない強制断とかでゴミが残るから
それの対策も必要
powershellで
インターネットのテキストファイルを
ダウンロードしてunix形式からWindows形式で保存したいんですが、bitsadminだとunix形式で保存されて文字列が二重にずれて保存されます。
どうにかならないですか?
>>349
なんでPowershellを使うか不明だが
落としたテキストをfirefoxで開いてコピペすればいいのでは? >>350
何個か一気にダウンロードしたいので。
それを4つくらい作って、一つだけunix形式なので
ボタン一発で全部Windows形式にしたいんです。一々サイト開いてコピーより楽なので。
なんでバッチのbitsadminだと無理でしたわ。 コマンドのせいとは思えないんだけれど
手動でダウンロードすると勝手にwindows形式とやらになってるの?
スクリプトだけでやりたいならダメだけど、nkfとか使って変換しちゃえば。
bitsadminはコマンドプロンプト用コマンドで、powershell用ではない。使えなくはないはずだけど。
ダウンロードで文字エンコードの変換というのはできないので、ダウンロードしてから変換すればいいだろう。
powershellでダウンロードしたら奇麗にできました。
Unix形式TXTの文字ずれ。
powershell でもっと意外なことできないですか?
>>358
様々なことができますよ。
私は、データマイニング機能のコマンドレット造ろうと思ってますし
統計のコマンドレット作ったらどれだけ簡単に使えるかと思います。
簡単に言えばパイプでコマンドレットつなげば、統計処理が簡単に行える。
現在はExcelの自動化やってますよ。Access使わないようにしたいので。
さらにインタラクティブにExcel動かせますから(つかえそう)と思って
ます。 >>363
冗談で書いたつもりが、あるとは・・・ありがとん。 >>361
すごいですよね。時間がモロに短縮できたり。 >>367
そのまま使うのもいいでしょうけど
言語知識あるひとなら、C#でコマンドレット作ると
相当面白いものができると思いますよ。
そのうち、みんなシェアしあうようになるんじゃないかな。
作るのが結構簡単なので。
そうだC#などでなくても、PowerShellでコマンドレット作れたんだった
速度は遅くなるけど。面白いと思う。 PowerShellでデフラグをやるのを作れと言われたのに
ネットで調べても全然分かりません
誰か助けて下さい
お願いします
後払いでいいですよね
今日中にお願いしますね
>>373
defrag.exe c:
って書いときゃいいだけ それだけだと寂しいから
$drive=Read-Host "どのドライブをデフラグしますか?"
defrag.exe $drive+":"
>>376
派遣ITの仕事でパワーシェルでデフラグするのを作る仕事だと言われたのです
言ったのはその派遣会社の先輩です
>>377
一言でいいのでしょうか?
もっと長いものになるのでは? >>377
PS C:\Users\user> defrag.exe c:
Microsoft ドライブ最適化ツール
Copyright (c) Microsoft Corp.
操作に必要な特権がないため、ストレージ最適化ツールを開始できません。 (0x89000024) defrag.exe使っていいのかOSのAPI(知らん)使っていいのか.netをこねくり回してどうにかするのか
それくらい確認してから聞け
PS C:\Users\user> $drive=Read-Host "どのドライブをデフラグしますか?"
>> defrag.exe $drive+":"
どのドライブをデフラグしますか?: c
Microsoft ドライブ最適化ツール
Copyright (c) Microsoft Corp.
指定したボリューム パスは無効です。 (0x89000001)
>>381
PowerShellで断片化をどうこうぐらいしか言われていません
というか神ぺらに書いてあっただけで詳細は不明です
まさか、コマンド1つで済む仕事ではないと思います
何しろ数か月かけてやるらしいので、、、 gwmi win32_logicaldisk -Filter DriveType=3 | %{
$drive = $_.DeviceID
$disk = gwmi win32_volume -Filter "DriveLetter='$drive'"
$def = 1 | select Drive,DefragRecommended
$def.Drive = $drive
$def.DefragRecommended = ($disk.DefragAnalysis()).DefragRecommended
$def
} | ft -auto
ちなみに私はパワーシェルを勉強し始めてまだ3日です、、、
Drive DefragRecommended
----- -----------------
C: False
これはデフラグいらないってことかな?
本屋でパワーシェルの本を探したけど売っていなくて
結局応用情報用の本を2冊買いました
今回でとって縁を切りたいです
$Servers = "CSEPULTAPU01"
ForEach ($Server in $Servers)
{
$vol = Get-WmiObject -Class Win32_Volume -ComputerName $Server -Filter "DriveLetter = 'c:'"
$res = $vol.Defrag($false)
if ($res.ReturnValue -eq 0)
{
Write-Host "Defrag succeeded."
}
else
{
Write-Host "Defrag failed Result code: " $res.ReturnValue
}
}
というかパソコンではできないけどデフラクコマンド打つわけじゃないような
何とか.ps1ファイルを作って実行するらしいけどよく分からない
まあ給料が出るか分からないけどまあ適当にやるよ
使えないと思われて首になったらなったでいい
どうせ頑張っても前の会社でもひどくいわれるだけだたt
とりあえず、落ち着こうよw
PowerShellだけで、デフラグは出来ないから!
上司はスケジューリング的な事を言ってるんじゃないの?
毎週月曜日にデフラグを実行みたいな・・・・
車輪の再発明だとして、ファイルの断片化を見つけたり、それを直したりできるものかね?
>>392
多分そうだと思う
デフラグのコマンド打つだけなら、コマンド知ってればすぐ終わるものね
仕様書とナントカとも言っていた
>>393
その可能性はあるけどよく分からないからなあ
今日も出勤したらネットで調べながらいじってはみるけど
その人言葉が足りなくて説明伝わらなかったりするからデフラグだけじゃないでしょう
>>394
デフラグが必要かチェックして
デフラグして
後if文がどうやらと
パワーシェルやったこともないし本屋2件回ったけどそれ関係の本ない
ネットのサイトでちょっとしたコマンドとかは分かったけど
まあいいよ
もしできなくて使えねえって切られてもどうでもいい
何か追い込まれる状況になったら辞めるだけ chkdsk c: /fとsfc /scannowもやっとかないと意味ないよって言っとけ
Win32_Volume Class DefragAnalysis sample using PowerShell
# get volumes on local system
$v = get-wmiobject win32_volume
# Display Number of volumes
"Number of volumes {0}: " -f $v.length
# Now get the C:\ volume
$v1=$v | where {$_.name -eq "C:\"}
# Perform a defrag analysis on the C: drive
"Performing Defrag Analysis"
$dfa = $v1.DefragAnalysis().DefragAnalysis
# Display results
"";"Defrag Results - defrag of C:"
"-----------------------------"
"Average File Size (KB) : {0} KB" -f ($dfa.AverageFileSize/1kb)
"Average Fragments per File : {0} " -f $dfa.averageFragmentsPerfile
"Average Free Space per Extent : {0} " -f $dfa.AverageFreeSpacePerExtent
"Cluster Size (KB) : {0} " -f ($dfa.clustersize/1KB)
"Excess Folder Fragments : {0} " -f $dfa.ExcessFolderFragments
"File Percent Fragementation : {0} " -f $dfa.FilePercentFragementation
"Fragmented folders : {0} " -f $dfa.FragmentedFolders
"Free Space (GB) : {0} GB" -f ($dfa.FreeSpace/1gb)
"Free Space Percent : {0} " -f $dfa.FreeSpacePercent
"Free Space Percent Fragementation : {0} " -f $dfa.FreeSpacePercentFragementaion
"Largest free Space Extent : {0} " -f $dfa.LargestFreeSpaceExtent
"MFT Percent In Use : {0} " -f $dfa.MFTPercentInUse
"MFT Record count : {0} " -f $dfa.MFTRecordCount
"Page File Size : {0} " -f $dfa.PageFileSize
"Total Excess Fragements : {0} " -f $dfa.TotalExcessFragements
"Total Files : {0} " -f $dfa.TotalFiles
"Total Folders : {0} " -f $dfa.TotalFolders
"Total Fragmented Files : {0} " -f $dfa.TotalFragmentedFiles
"Total Free Space Extents : {0} " -f $dfa.TotalFreeSpaceExtents
"Total MFT Fragments : {0} " -f $dfa.TotalMftFragments
"Total MFT Size : {0} " -f $dfa.TotalMftSize
"Total Page File Fragements : {0} " -f $dfa.TotalPageFileFragements
"Total Percent Fragementation : {0} " -f $dfa.TotalPercentFragementation
"Total Unmovable Files : {0} " -f $dfa.TotalUnmovableFiles
"Used Space (GB) : {0} GB" -f ($dfa.UsedSpace/1gb)
"Volume Name : {0} " -f $dfa.VolumeName
"Volume Size (GB) : {0} GB" -f ($dfa.VolumeSize/1gb)
Number of volumes 6:
Performing Defrag Analysis
Defrag Results - defrag of C:
-----------------------------
Average File Size (KB) : 0 KB
Average Fragments per File :
Average Free Space per Extent :
Cluster Size (KB) : 0
Excess Folder Fragments :
File Percent Fragementation :
Fragmented folders :
Free Space (GB) : 0 GB
Free Space Percent :
Free Space Percent Fragementation :
Largest free Space Extent :
MFT Percent In Use :
MFT Record count :
Page File Size :
Total Excess Fragements :
Total Files :
Total Folders :
Total Fragmented Files :
Total Free Space Extents :
Total MFT Fragments :
Total MFT Size :
Total Page File Fragements :
Total Percent Fragementation :
Total Unmovable Files :
Used Space (GB) : 0 GB
Volume Name :
Volume Size (GB) : 0 GB
デフラグのスケジュールとか、対象になるマシン・デバイスを自動的に
洗い出す機能とか、そういうのを期待してるんだろうな。
そんでもって、デフラグ終了情報とかデバイスのエラー情報とかが
一覧で見られる機能。
そんなんかな?
要件を口頭で訊きとって紙ペラか課題管理表かRFPを作れ、まずはそれからだ
>>401
そうかもしれない
今はもう応用情報の勉強ばかりです
これが最後のIT資格 詳細な要件の洗い出しからしないと二度手間三度手間どころではすまんことになりそうな気が
その指示を出した上司に仕様書かかせるなり、自分が仕様書書くために必要な条件聞き出した方がいいと思う
今後のメンテも必要になってくるだろうからドキュメント化しておいた方がいいと思う
>>405
PowerShellで断片化だとかデフラグだとかアナリシスだとかしか言われていません。 その状況で「やれます」「やりみます」と言ってはいけない。
なんとなく上司も要件をきちんと把握できてないかも臭を感じる。
「要件定義からやりますか?要求や基準はどこに当たればよさそうですか?」からかな…
PowerShellよりコミュニケーションを学んだほうがいいやつか。対上司にせよ対スレ民にせよ
上司の話もちゃんと聞いてないようにしか見えん
仕事を進められるか、スケジュールが組めるか、がまず試されてる気がする
言われていませんじゃなくて、おまえが積極的にインタビューするんだよ!!
仕事として言われたなら当然今後の維持・メンテ等も考慮する必要があるはず
ずっと自分が関わっていくなら間に合わせで仕上げてもかまわんかもしれんけどさ
いざ部署異動発令されて急にドタバタしてるところに
移動までに仕様書出してねとか言われるのは嫌だろうし
しかも時間が経ってたりすると自分でも忘れちゃってたりする部分が出てきて
頑張って思い出そうとしたり再度調べたりしなきゃいかんとか嫌すぎる
つうかなんでスレチのコミュ障の相手をするわけ?
そういうことすると居着くからやめて欲しい
結局自分のことにしか興味なくて相手にどうわかってもらえるかとか考えてないんやろ
そんなん転職してもうまくいかんわ
応用情報ってなにかと思ったら昔の第1種なんだな
俺は第2種をCASLとCOBOLで受験して落ちたぜーw
よくわからないからこういう書き方になっただけ
もう仕事はどうでもいいから応用情報だけ取って引退します
私は能力的にもう無理だ。
頑張っても分からないし、もう衰えているからどうしようもない。
数か月間の小遣い稼ぎだと考えることにする。
4月に受ける応用情報技術者試験で最後にしたい。
パワーシェルはまだまだ全然怪しいが、出勤時は多少は勉強しよう。
自分の給料はいくらになるのだろうか。
最後は裏切ることになるから、それまではおとなしくしておこう。
ディスク断片化監視システムの構築
Windowsサーバのディスク断片化を検知する仕組みの検討、作成、実装
断片化閾値検討、断片化検知PowerShellの作成、テスト
PowerShellを本番機に実装、PowerShell設計
Windowsサーバ構築、JP1/AJS、タスクスケジューラ
サーバ定期点検、リソース状況の分析、障害対応作業、パッチ適用作業
システムの運用保守設計作業、ドキュメント作成
仮想化、VMware、Hyper-V、運用監視ミドルウェア、JP1、
運用設計、アンチウイルス、DeepSecur、バックアップ、ログ
ネットワーク、容量、クラウド上での基盤構築
>>418
第1種ってもう20年近く前になくなったぞ >>421
それが上司がくれた「紙ペラ」のメモなら、色々要件が書いてあるじゃないか。
しきい値やログ、チェック頻度をどうするかの発案〜検討〜調整が含まれる、スケジュール化はタスクスケジューラとAJSどちらかを選べる、発報先はJP1なんだろうな だからなんでキチガイに触るかな
そんなに背景読み取れる俺様凄いをしたいわけ?
>>426
おまえの快不快なぞ知ったことか、嫌ならあぼんしとけ 誰もここにパワーシェルのスクリプトを書いてくれない、、、
もう諦めました
どうせ数か月で辞めるからどうなってもいいです
PowerShell使ってみようかと思ったんだけどコマンド操作だけじゃ使い難くてしょうがないな
昔のMSDOSみたいにFDとかFILMTNとかDOSShellみたいなユーティリティーは無いのかこれって?
ユーティリティが使いたければ普通にGUIアプリを起動すればいいのでは?
>>431
CUI時代の化石の話はやめるんだ
まあPowerShellでやると冗長な操作もあるしそういうのは従来のコマンド使ってねって感じで割り切って作られてる 俺が初めて触ったOSは・・・MS-DOS3.0なりー
>>431
海外にはあるようなので、ネットで探ってみて Powershellを始めてまだ数日
実際に何日やっているかもよく分からない
最大でも6、7日かな
コマンドもまだ覚えきれていない
シャットダウンとかも見ながらやっていた
ただ、Stop-Computer -Force、とようやく覚えられたぐらい
はっきり言って、現場に入っても使えねえ扱いされる可能性がかなり高い
だけど、それでもいい
今回は数か月間お金を稼げればいい
自分が正社員じゃなかったり、今月の給料が出ない可能性もあるし
何せいくら給料が出るのかも分かっていない
それでもおそらくこれがIT業界で最後の仕事になるでしょう
ここを最後にITとは縁を切ります
さようなら
自分の受けた仕事をここに丸投げしようって腹が気に食わない
軽自動車ですら運転したことのない奴に大型ダンプを運転させるようなことを、なぜこの業界はやるんだろうな。
そんな馬鹿の面倒を見させられる現場の人が可哀想でならない。
とりあえずPowershellのコマンドを全部覚える必要はないw
psのコマンドレットは割と糞だらけだから.NETの呼び方覚えた方が捗る
>>438
何日もネットで色々調べて分からないから追い込まれてここで聞いただけです。
もうどうでもいいです。
どうせ6月で辞めます。
色々お世話になりました。
さようなら。 数ヶ月の仕事をここで書いてもらうってさすがに無理だろ
大抵の見積もりでは、一人月1000〜2000ステップはいるぞ
要件不明瞭で丸投げされてもどんなプロでも正答はできない(の割に色々なアドバイスはきちんとした)。
これでなにも答えてないというなら今すぐ仕事を降りろ。迷惑だ。
もう分からないから諦めました。
コマンド1つでも書き込んでくれた方はありがとうございました。
私はもう辞めることを決意致しました。
やれるだけのことを頑張って、怠けていると暴言を受けるでしょうね。
今までお世話になりました。
さようなら。
さよならは別れの言葉じゃなくて〜 再び会うための遠い約束ぅ〜
うわごとの様に同じ事を繰り返し書きつつ、その自覚もなさそうだ。
お前さんは健常な判断力を失ってしまった精神が病気の状態
なにはともあれきちんとした精神科でカウンセリングを受けること
そりゃ病むよ
頑張っても分からない
頑張った結果、受けるのは暴言のみ
能力は低いけど調べても何をすればいいのかよく分からない
だけど別に駄目なら辞めればいいだけ
1社面接の予定も入れてみた
同日にもう1社は入れるか考えたけど多分入れない
一応、可能な限りはやってみることにした
ただし、優先するのは応用情報技術者の勉強
これを取って二度とSEはやらない
>>450
まず第一にやることは上司と相談すること
自分が何を悩んでいるのか話してみること 相手をする奴がいるから湧いてくるってことに、なんで気づけないのかな。
馬鹿なのかな。
普通でまともなコミュニケーション出来ないかぎり、できる仕事は限られる。
ライン作業や清掃員とかなら何とかなるかな
刺身の上にタンポポをのせる仕事
コミュ障のキミにマジおすすめ
2019年2月に入社しましたが
面接の時に社長に言われた新人でもできる仕事というのが嘘でしたし
給料も入社月には出ないし
PowerShellをネットで検索しても良い情報が少なく
どうすれば良いのか分からないです
おそらく頑張ってもできるようにならないでしょう
だから残り62日間は応用情報技術者試験のことだけを考えます
昨日で今の会社を退職する決意をしました
だから残り数ヶ月で今の人達全員と縁を切るわけですから
どう思われても構いません
どうせどんなに頑張っても無駄で怠けている扱いを受けて
使えないと暴言を受けて追い込まれるだけでしょう
会社の先輩も人間的に嫌いですしもうどうでもいいです
一応多少PowerSherrをやりながら応用情報技術者の勉強の方を重視します
これのここの部分が分からないのですがと質問できるレベルならば
単純にそれをグーグルで検索すればいいだけです
どうせ聞いても無駄です
応用情報持っててもあまり意味ないのは内緒だよ・・・
すんません、教えてください。
Edgeを自動操作することはできるのですか?
フォームに名前や数値を記入し、ボタンを押すなどということはできるのですか?
UWSCでIEを操作しているのですが、そのかわりに使えないかと思っているのです。
よろしくお願いします。
>>455
>PowerShellをネットで検索しても良い情報が少なく
>どうすれば良いのか分からないです
先に『何をやるかがあって、そこでPowerShell使う』これが先にないと
良い情報とか有りえないですよね。
何見ていいいかすらわからなくなっちゃう。 >>461
ここはお前の日記じゃない
Twitterでやっとけ 何かを始めるのにはまずはネットとかから2、3サンプルを拾って
自分の環境で実行してフィーリングをつかむ事でしょうね
その後に何かの課題を自分で見つけてググりなからでも実行しながら身に付けていくといいでしょう
検証作業をしなからじゃないと何でも身に付きませんよ
その内に各コマンドのパラメーター内容も理解出来るレベルになるでしょう
まずはdefrag.exeがあるシステムフォルダのパスを取得してみましょう。
>>461
すくなくとも、今はないですね。
利用価値がないのではなくて、仕事出す方が利用価値をしらないから
将来的には十分あると思う。
でも「PowerShell使えるひといますか〜?」ではなくて
パッケージ的に、特殊なコマンドレットなどをつくって商売にする
という形なのではという気がしている。
あくまで、気がしているだけですけど。 独学で何を学べば仕事があるんだろう?
PHPかな?
>>468
何を作るかで必要な言語が見えてくる。ー AzureAD、Office365を使うなら(Office365についてはGraphの使いこなしも必須)。バッチやVBSの代替としても必須。
「Powershellが出来る」だけではなくPowershellも活用し、なんの業務をしてたか?がスキルとなる。
基本的にはインフラ屋のスキル要素
powershellはロードが重いからログイン時に何かさせようとするとワンテンポ遅れてしまうね。
C#で組むかな。
俺はログインスクリプトは、WSHで間に合うならjscriptを使うな
>>471
必要になったところだけC#と組み合わせができるのが
PowerShellの良いところでもあるんで、いいんでない? 趣味プログラミングでPowerShell使ってるけど、
ドキュメントとか解説サイトがC#/.NET知ってる前提みたいなのが多くて大変
英語圏のサイトにはお世話になる
PowerShellで内容のあることやろうと思ったら.NETは必須でしょ
言語仕様の知識だけじゃどうにもならん
>>476
あ、一緒です。
英語不得意なのに、向こうのサイトにお世話になってる。
日本は管理用ばかりみたいに使ってるけど
向こうはいろいろあって、アプリ的な利用もされているんで
面白い。 誰か断片化が10%以上ならデフラグを行うスクリプトを書いて下さい
danpenkacheck.ps1とかで
if($断片化率 -ge 0.1){やれ-でふらぐ}
defrag.exeを -a -v で起動してその結果をパイプで受け取れば良いんじゃね?
if($断片化率 -ge 0.1){やれ-でふらぐ}
defrag.exe -a -v
format c: /x /p:10
PS C:\Users\user> if($断片化率 -ge 0.1){やれ-でふらぐ}
>>
>>
>>
>>
>>
>>
>>
>>
>>
>>
>>
>>
PS C:\Users\user> defrag.exe -a -v
Microsoft ドライブ最適化ツール
Copyright (c) Microsoft Corp.
操作を実行するボリュームを指定してください。 (0x89000007)
説明:
システムのパフォーマンスを向上させるため、ローカル ボリューム上の
ファイルを最適化します。
構文:
PS C:\Users\user> format c: /x /p:10
アクセスが拒否されました。十分な特権がないか、ディスクが別の
プロセスによってロックされている可能性があります。
このユーティリティの実行は管理者特権モードで起動する必要があります。
また、ディスクのロックが解除されていることを確認してください。
ダイレクト アクセスのためにボリュームを開けません。
ITエンジニアは知らない知識にぶつかった時調べる能力がないとやれない。
今回の例ならエラーメッセージをそのまま""で囲ってググればいくらでも対処例が見つかる
そんなこともできなくなったなら自分が異常だと認めるしかない。
病院へ行け、いますぐ一線を退け。
こいつはさすがに愉快犯だろ…
あるいはPoweshellで書かれた高度AIかもしれない
サヨナラ
サヨナラ
サヨナラ
冗談ならさておき何も考えずにformatコマンド流しちゃうようなのは困るわw
>>495
初心者がやったとしてもCドライブである限りロックされていて不可能だから被害はない
やるとしたら回復環境を起動したコマンドプロンプトで実行しない限り無理です Cドライブフォーマットが駄目でもファイル全消去ならイケるのか
>>496
何も考えずに流しちゃうのは困るでしょ
仮にシステムドライブ以外だった場合どうなるのかと
基礎的な知識くらい持った上でやらんとあかんってこと 中傷IT企業に入社してネットで色々調べながらやってもいるけどどうしてもわかりません
というか要件を聞いて何をすればいいのかもわかりません
この分だと使えないときられるでしょう
そう言われても頑張ってもどうしようもないので困っています
ITには向いていないのにITにしか採用されないなんて
案件 ディスク断片化監視の構築
作業内容
Windowsサーバのディスク断片化を検知する仕組みの検討、作成、実装
・断片化閾値検討
・断片化を検知するPowerShell作成、テスト
・PowerShellを本番機に実装
スキル
・PowerShell設計、作成
・Windowsサーバ構築
・JP1/AJS、タスクスケジューラ
powershellの本自体が複数の本屋を見たけど売ってなかった
アマゾンで評判を見たら結局スマホで調べたとか感想があったりで
本も役に立たなそうなのと結局あまり使われていないスキルってことか
時間がかかり過ぎているとか言われているけどどうすればいいか分からないから
このまま止まっているだけになってしまう
これはやれるわけないってのが正直な感想だな
それでも一応は考えるけど必要な情報もなくてどうしろというんだか
逆に優秀だったら今の中小ITには来なかったのは明白なんだよなあ
育てれば使えるようになるかもしれない人材を会社はどうするんだろうね
for文の意味から分かっていない
for($i=0; $i -le 10; $i++) {
"カウンター : $i"
}
# 実行結果
カウンター : 0
カウンター : 1
カウンター : 2
カウンター : 3
カウンター : 4
カウンター : 5
カウンター : 6
カウンター : 7
カウンター : 8
カウンター : 9
カウンター : 10
もうこない、もう書き込まない、2月で止めるからどうでもいいって何度繰り返してるんだよ
個々はあんたが愚痴を書き込んだりあんたの愚痴を聞いたりするところじゃないの
職歴にしたいのならLinkedInにでもアカ作って書き込んでなさいな
今はこれを1回試しただけ
応用情報の過去問を印刷して
それに答えを書き込んでいます
ITは嫌でやりたくないけど
>>506
2月ではやめないよ
少しは様子を見るし
今は早く帰れるからリハビリ扱いにしている コボラーになるかな
COBOLが人気ないなら
それを覚えて
運用保守でも監視でも何でもいい
そのわかんないというのは、
PowerShellが分からないんじゃなくて、やり事柄の知識
いわば業務知識のひとつだな。
断片化などの意味と、そちらを調べだすユーティリティーなどの知識
そして、それが業務や経営に与えるコストのインパクト。
そういった知識ががないという話ですね。
それがあれば、言語は何使ってもいいし、PowerShell使うときには
PowerShellの何を覚える必要があるかは、自ずとわかってくる。
>>505を見るにPowerShellうんぬん以前の問題だし
これ分からんかったらPowerShellどころかおそらくどの言語でもダメだろうに 育てれば使えるようになるかもしれない人材という自己認識があるのかいな
悪いこと言わないからCOBOLを含めてITは全部もう手を出すな
さっぱり向いてないことに頑張っても現に辛いだけだろ
給料安くても日光のもとで体動かす仕事がメンタルにもいいぞ
資格の勉強より筋トレをしろ
>>510
おまえ現実での人の対応もこの掲示板の連中に対する対応と同じだろ
死んだほうがいいぞ バブルの頃は入社して変数とは?から教えてくれる会社があったけど
今はある程度知識がないと厳しいんじゃね?さすがにfor文ぐらいは理解してないと厳しいよ
>>500
検索したらヒントはあるけど、スクリプトを書くしかない。
断片化を表示するコマンドはありますねw Windows PowerShell
Copyright (C) Microsoft Corporation. All rights reserved.
PS C:\Users\user> Optimize-Volume
コマンド パイプライン位置 1 のコマンドレット Optimize-Volume
次のパラメーターに値を指定してください:
DriveLetter[0]:
PS C:\Users\user> Optimize-Volume C
Optimize-Volume : Access denied
Activity ID: {bca1b272-eaf1-4a38-88ce-09620bbb75b7}
発生場所 行:1 文字:1
+ Optimize-Volume C
+ ~~~~~~~~~~~~~~~~~
+ CategoryInfo : PermissionDenied: (StorageWMI:ROOT/Microsoft/...age/MSFT_Volume) [Optimize-Volume], CimE
xception
+ FullyQualifiedErrorId : StorageWMI 40001,Optimize-Volume
Optimizes a volume.
音量を最適化します。
This example reports only the current optimization state of drive H.
この例では、ドライブHの現在の最適化状態のみを報告します。
This example defragments drive H.
この例は、ドライブHを最適化します。
各ドライブにデフラグが必要か調べる
wmi win32_logicaldisk -Filter DriveType=3 | %{
$drive = $_.DeviceID
$disk = gwmi win32_volume -Filter "DriveLetter='$drive'"
$def = 1 | select Drive,DefragRecommended
$def.Drive = $drive
$def.DefragRecommended = ($disk.DefragAnalysis()).DefragRecommended
$def
} | ft -auto
この構文を解釈すると何か変数に色々入れている
PS C:\Users\user> wmi win32_logicaldisk -Filter DriveType=3 | %{
>> $drive = $_.DeviceID
>> $disk = gwmi win32_volume -Filter "DriveLetter='$drive'"
>> $def = 1 | select Drive,DefragRecommended
>> $def.Drive = $drive
>> $def.DefragRecommended = ($disk.DefragAnalysis()).DefragRecommended
>> $def
>> } | ft -auto
wmi : 用語 'wmi' は、コマンドレット、関数、スクリプト ファイル、または操作可能なプログラムの名前として認識されません。
名前が正しく記述されていることを確認し、パスが含まれている場合はそのパスが正しいことを確認してから、再試行してください
。
発生場所 行:1 文字:1
+ wmi win32_logicaldisk -Filter DriveType=3 | %{
+ ~~~
+ CategoryInfo : ObjectNotFound: (wmi:String) [], CommandNotFoundException
+ FullyQualifiedErrorId : CommandNotFoundException
断片化の閾値をいくらにするかとか
断片化が何%か確認するパワーシェルが分からない
defrag.exeが断片化率を返してくれるだろー
自己学習でどうにもならんならどっかの企業教育受講しに行くしかなかろうて
5ちゃんねるは無料サポートの場じゃないんだぞ
手取り足取り無料サポートしたとしても伝わる相手だとは思えない
上司を言葉足らずなところがあると評したように、分かるように教えてくれないと恨まれる未来しか想像できない
>>528
どうもです
断片化率が返っていたのですか
>>535
ボリュームの情報を取得するエアしいです
エイリアスです >>512
何も分からないですね
スクリプトの構文も読めないですし
こういうのを解釈してくれるサイトでもあれば良いのですが 「誰か断片化を検知するパワージェルを教えてください
>>525はワザとかコピペミスか知らんが先頭の一文字が欠けてるだけ >>536
エイリアスといったって、
エラーに『そんなのないよ〜』って出てるけど >>537
自分であれこれやって分からんのだったら自費なり会社に金出してもらうなりして
企業がやってるPowerShellの教育受講してこいよ
そこで教わって分からんところは徹底的に聞けば良かろう
ここでいつまでもグダグダやられたって迷惑だって言われてるの分からんのか? PS C:\Users\user> gwmi win32_logicaldisk -Filter DriveType=3 | %{
>> $drive = $_.DeviceID
>> $disk = gwmi win32_volume -Filter "DriveLetter='$drive'"
>> $def = 1 | select Drive,DefragRecommended
>> $def.Drive = $drive
>> $def.DefragRecommended = ($disk.DefragAnalysis()).DefragRecommended
>> $def
>> } | ft -auto
Drive DefragRecommended
----- -----------------
C: False
PS C:\Users\user> gwmi win32_logicaldisk -Filter DriveType=3
DeviceID : C:
DriveType : 3
ProviderName :
FreeSpace : 98662301696
Size : 158981132288
VolumeName : Windows
PS C:\Users\user> gwmi win32_volume -Filter "DriveLetter='C:'"
PS C:\Users\user> 1 | select Drive,DefragRecommended
Drive DefragRecommended
----- -----------------
>>545
これでいいやん。デフラグが必要ならtrueで。 >>556
たった数行で6月までの仕事なのか
楽でいいな 上司から課せられた真の業務命令はいかに他人に無償でプログラムを書かせるかという課題であった
納期まで言い切った
これ無能君の上司動き始めてるだろw
いまは重さで料金を決めるのが一般的
200グラム1000円とか
ドキュメント、粘土板に象形文字で書いてもいいんかね?
ショートカットキー Alt + F4 で窓が閉じないのです 他に方法ありますか?
Windows10です
あれはあってもなくても良かった
メディアが話を大きくして死人がでたが
「あの日」では数千万円の印税でぼろ儲けさせて戴きました
エクスプローラーやアプリをダークテーマにする操作をpowershellで出来ますか?
ちなみに10の1809です
How to Enable Dark Theme on Windows 10 - Appuals.com
https://appuals.com/how-to-enable-dark-theme-on-windows-10/
$keys = 'HKLM:\SOFTWARE\Microsoft\Windows\CurrentVersion\Themes\Personalize', 'HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Themes\Personalize'
$keys | Where-Object{-not (Test-Path $_)} | Foreach-Object{New-Item $_}
$keys | Foreach-Object{New-ItemProperty $_ 'AppsUseLightTheme' DWORD 0}
かな 位置パラメータじゃなかった
$keys = 'HKLM:\SOFTWARE\Microsoft\Windows\CurrentVersion\Themes\Personalize', 'HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Themes\Personalize'
$keys | Where-Object{-not (Test-Path $_)} | Foreach-Object{New-Item $_}
$keys | Foreach-Object{New-ItemProperty $_ 'AppsUseLightTheme' -PropertyType DWORD -Value 0 -Force}
でいけるはず(作成済みの場合は上書き)
PowerShellのソースを隠蔽するのにいい方法ってないですか?
PS2EXEでexe化するという方法もあるけど、これだと引数の引き渡しができないですよね。
PowerShellは使い捨てかプロトタイプ作成用じゃないの?
隠したいならC#とか使いなよ
>>588
そーなんです。
PS2EXEでサンプルプログラム組んだんですが、引数を単なるパラメータとしか認識してくれず・・・
PS2EXE-GUIは開発がストップしているらしくノーチェックでしたが
リンク先の情報いけそうですね!ありがとうございます! >>589
良かった。
ちなみに、PS2EXEが開発ストップして引き継いだのがPS2EXE-GUIだよ。 RuntimeBroker.exeとSecurityHealthSystray.exeがバックグラウンドで動いているのを止めたいのですがどうしたら良いのでしょうか?
無条件に止めていいのなら
Start-Process powershell -Verb RunAs -Command "Get-Process RuntimeBroker*,SecurityHealthSystray* | % {`$_.Kill()}"
サービスを止めるのならSysInternalsのprocexpとかでそのプロセスのサービス名を調べて
Start-Process powershell -Verb RunAs -Command "Stop-Service `"RuntimeBrokerのサービス名`";Stop-Service `"SecurityHealthSystrayのサービス名`""
スマホから書いてるので試してない
>>592
ありがとうございます、レジストリをいじっても止まらなかったので試してみます。
後cortanaやedge等アンインストール不可なものはスタートメニューからもピン止めを外せないのですがどうすればよいでしょうか?
アンインストール不可とはいえタスクを切った上でフォルダ名を変更すれば疑似的にアンインストールは出来るのですが・・・ それはPowerShellの話からかけ離れてないか?
PS全く分からず(こう書いたけどうまくいかない等が何もない)
単にCortanaやEdgeのピン止めを外したいというのであれば
Win10の質問スレが妥当なんじゃないすかね
>>596
それが通常では外せない為強制的に外すしかないんですよ その強制的な手段も含めてOSなりアプリなりのスレでどうぞ
学習コストも支払わずに(少しも勉強せずに)タダでコード書いてもらうスレじゃない
上のデフラグ君といい最近ちょっと目に余る
いずれにしろこのスレは○○じゃないとか言ってしまうのは不味いよなあ
別にスレチでは全く無いわけだし
そうだね
>>598みたいに親切に解説する必要もなくスレチは放置すりゃ良い まあPowerShellでやれるなら別にスレチでは無いだろ、ちょっと初心者かも知らんが
これ以上は止めよう
このスレはパワーシェルスレだからそれに関する話題を仲良くやっていこう
勢い皆無のスレで言い争っても益々過疎るだけで何の益もないよ
ここで書くよりはMicrosoft Communityで書いた方が有意な回答得られそうな気がするんだがなぁ
>>603
それを言い出したら何だってスレチじゃなくなってしまうだろ
少しは頭を使えよ 2月にダラダラ居座ったメンヘラ丸投げくんのせいで過敏症気味だね
たとえばレジストリエディタで一度設定すれば済むような問題で
設定すべき項目と値を教えてくださいという質問だったら
そりゃどんな書き換えもPowerShellでできるけれどもWindowsの質問だわな
使えないと思われたのか切られました
今までありがとうございました
さようなら
結局2月3月と一切何の仕事もしないで給料貰ったのか
うまいことやったな
自己都合の退社じゃないなら、失業保険はすぐに貰えるから職安へGO!
使用期間3ヶ月以内での解雇としてその企業は逃げているんだろうから
本人の保険給付期間が残っていなければ貰えませんね
何マジになってんの?w こんな馬鹿が実在するとでも
困ったのはいいとして、自業自得な馬鹿のアフターフォローですか??w
(アフターフォローの意味が分かってない感じの人だが黙っていよう)
業務用のコードの丸投げの問い合わせを受け、皆でうんざりしつつ対応したが
結局クビになって問題も霧消したのに、収入の心配をしてあげてることを指しているのだが?
馬鹿と言うかアスペルガーだな
結構居るんだよこういう人
あんまり構うと気にかけてくれてると感じて近況報告したり次の人生相談を始めかねない
ここPowershellのスレだし正常化してほしい
PowerShell Core、次のバージョンから「PowerShell 7」に変更
2019/04/09 08:25:56 後藤大地
https://news.mynavi.jp/article/20190409-804804/
Microsoftは4月5日(米国時間)、「The Next Release of PowerShell - PowerShell 7|
PowerShell」において、先日公開したばかりの「PowerShell Core 6.2」について、次の
バージョンはPowerShell Core 6.3ではなく「PowerShell 7」になると伝えた。
大幅な機能変更があるわけではなく、リリースエンジニアリングの変更やプロダクトの
ポジション変更が名前の変更理由になっている。MicrosoftはついにPowerShell Coreで
Windows PowerShellを置き換えていく方向に舵を切り出したようだ。
Windowsには、もともと存在していたWindows PowerShellと、新たにオープンソース・
ソフトウェアとして公開されたPowerShell Coreという2つのPowerShell系実装が存在して
いる。開発の主体はPowerShell Coreであり、さらにその多くがLinuxからのフィード
バックで開発されている。
今回、MicrosoftはこうしたPowerShell Coreで実現された成果をWindows PowerShellに
導入できないと(Windows PowerShellはすでに開発が終了しており、変更の取り込みは
行われない)説明している。
これに対し、PowerShell Coreでの成果をWindowsユーザーにもたらす方法として、Power
Shell CoreをPowerShell 7と名称変更し、従来のWindows PowerShellから置き換えていくと
説明した。最初のレビュー版は2019年5月ごろに公開されると見られる。(後略) マイクロソフト、「PowerShell 7」を発表--5月にプレビュー版を公開へ
Liam Tung (Special to ZDNet.com) 翻訳校正: 編集部 2019年04月09日 10時11分
https://japan.zdnet.com/article/35135464/
(前略) PowerShellは人気プログラミング言語の指標「TIOBE Index」で3月に初めてトップ
50入りを果たし、45位につけた。その主な理由として、Linuxユーザーの間での人気の
高まりが挙げられる。
しかし、Windowsユーザーの間でのPowerShell Coreの人気は横ばいであり、およそ1100
万回におよぶPowerShellコマンドの起動回数(テレメトリが無効化されている場合を除いた
統計値)のうち、Windows環境から起動されたものの割合は20%にも満たない。
Microsoftは、Windows環境での利用をさらに推し進めるという目標の下、「Windows
PowerShell 5.1を完全に置き換える」ためのリリースを計画している。PowerShell 7により、
Windows PowerShellを使用していたユーザーと、他のプラットフォーム上でPowerShell
Coreを使用していたユーザーは、同一の機能を利用できるようになる。
さらにPowerShell 7によって、現時点におけるWindows PowerShellのモジュールとの
「極めて高い互換性」がユーザーにもたらされるという。(中略)
さらにPowerShell 7では、.NET Coreのサポートライフサイクルと歩調を合わせ、長期
サポート(LTS)リリースと非LTSリリースの双方が用意されるようになる。
PowerShell 7のプレビュー版は、5月にユーザーに向けてリリースされる見込みだが、
PowerShellと.NET Core 3.0の統合の進捗具合によって実際の日付は変わってくる。
Microsoftによると、.NET Core 3.0の一般提供を開始した後で、PowerShell 7の一般提供を
開始することになるという。
PowerShell 7は最終的にWindows PowerShell 5.1とともにWindowsに標準搭載されることに
なるが、「Windows 10」や「Windows Server」のどのバージョンからそれが実現されるのかは
まだ明らかにされていない。 cpuを制御するコマンドがあればいいね。
95%でタスクを切られたり
1桁に下がるまで全プログラム強制終了とか
cpuを制御するわけじゃないけど、パフォーマンスを監視して何かするということなら
Get-Counter
を使えば良いんじゃない?
$hoge = 'fuga'
get-ADGroup -Filter * -SearchBase $hoge
みたいに書いても、 $hoge が展開されず、まんま引数 $hoge って文字として扱われるんだけど、
get-ADGroup -Filter * -SearchBase fuga
って感じに展開させるのどうすればいいんだろ
実際は{ $hoge } とか '$hoge' みたいなことしてない?
返事ありがとう。
当然そんなことはしてないし
$hoge = 'fuga'
$hoge
get-ADGroup -Filter * -SearchBase $hoge
みたいに書いて実行すると
fuga
hoge : 用語 'hoge' は、コマンドレット、関数、スクリプト ファイル、または操作可
なプログラムの名前として認識されません。名前が正しく記述されていることを確認し
、パスが含まれている場合はそのパスが正しいことを確認してから、再試行してくださ
い。
発生場所 ***:** 文字:**
+ get-ADGroup -Filter * -SearchBase $(hoge)
+ ~~~~
って表示されちゃうんだ…
>>633
get-ADGroup -Filter * -SearchBase “$($hoge)“
でどうでしょう >>633
全角になっちゃったのでやり直し
get-ADGroup -Filter * -SearchBase "$($hoge)"
でどうでしょう >>633
おい
$(hoge)ってやってんじゃん
$( )はカッコの中身を実行してその出力を変数として渡すものだから
hogeをコマンドみたいに実行しようとしてそのエラーが出てる 皆コメント本当に助かる
>636
そこが一番気になってるんだ
$hoge
って書いてるのに、エラーでは
$(hoge)
として見られてる。こういう風にデフォルトで解釈されるような原因とかあるのかな…
>635
やってみました
発生場所 ***:** 文字:**
+ get-ADGroup -Filter * -SearchBase "$($hoge)"
+ ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
ですね。変数がやっぱり変数として解釈されてない気がします…
そんなら最初に変数として定義しとけばいいんじゃないの
途中で「echo」コマンドによる出力をしてみろよ
その後にpauseで一旦止めてな
>>633
とりあえずお前のコピペは信用できないからハードコピー貼れや >>642
だったら
$hoge = 'fuga'
の時点でエラーになるだろ C:\Users\hoge\Desktop\copy.ps1の内容↓
$watchPath = "C:\Users\hoge\Desktop\watch"
$destPath = "C:\Users\hoge\Desktop\dest"
$watcher = New-Object System.IO.FileSystemWatcher
$watcher.Path = $watchPath
$watcher.EnableRaisingEvents = $true
$action = {
$path = $Event.SourceEventArgs.FullPath
Copy-Item $path $destPath
}
Register-ObjectEvent $watcher -EventName Created -Action $action
while ($true) { Start-Sleep -s 1 }
このファイルを右クリックから[PowerShellで実行]またはバッチファイルから起動した場合、
watchフォルダにファイルができるとDesktopにコピーされます。
VSCodeやPowerShellISEから実行するとdestフォルダにコピーされます。
$actionスクリプトブロックの変数スコープが問題だと思うんですが、
どうすれば前者でもdestフォルダにコピーされますか?
>>645
すみませんPowerShellに不慣れなものでして
どのような構成にすればよろしいでしょうか PowerShell初級者です
コマンド プロンプトから呼び出しできません
ご教示よろしくお願いいたします
コマンドライン
powershell -ExecutionPolicy RemoteSigned -Command $a=New-Object Media.SoundPlayer(`"%SystemRoot%\Media\Windows Error.wav`");$a.PlaySync()
エラー内容
式に終わりの ')' が存在しません。
発生場所 行:1 文字:70
>>650
ファイル名を括ってるのバッククォート?
シングルクォートで試してみたら? >>651
ありがとうございました。m(_ _)m >>650
とりあえずエラーの直接原因は
SoundPlayer(`" … `");
だろうね
PowerShellのバージョン書いてないけどWindows10とかなら
New-Object Media.SoundPlayer("`%SystemRoot%\Media\Windows Error.wav`");
じゃなくて
[Media.SoundPlayer]::new('%SystemRoot%\Media\Windows Error.wav');
ってやった方がコンストラクタのパラメータの指定がやり易い >>655
そういうのウザいだけです。
間違ってると思うなら訂正してください。 「powershell バッククォート」でぐぐればすぐに正解が出てくるのに…
[Regex]::Replace("hoge123","([^ \d])(\d)","$1 $2")
「hoge 123」ではなく「hog 23」になります
ご教示よろしくお願いいたします
PS2.0
"$1 $2" は正規表現以前にPowershellとして文字列への変数$1と$2の挿入になるんじゃないか
単引用符にすればいけそう
パターンが悪い。
あと$はエスケープ文字`が要る
パターン…"([^\d]+)(\d)"
置換指定"`$1 `$2"
>>663,662
「$」のエスケープ「`$」で希望動作になりました
ありがとうございました。m(_ _)m C:\Users\nanashi\Desktop\aaa\bbb
C:\Users\nanashi\Desktop\aaa\ccc
C:\Users\nanashi\Desktop\aaa\bbb\eee
C:\Users\nanashi\Desktop\aaa\bbb\eee\eee01.txt
C:\Users\nanashi\Desktop\aaa\bbb\eee\eee02.txt
C:\Users\nanashi\Desktop\aaa\ccc\fff
C:\Users\nanashi\Desktop\aaa\ccc\fff\fff01.txt
C:\Users\nanashi\Desktop\aaa\ccc\fff\fff02.txt
こういう階層構造があって。フォルダを再帰的に aaa 直下に平坦に並べたいとします。
ls C:\Users\nanashi\Desktop\aaa -r | ?{$_.PSisContainer} | %{mi $_.FullName C:\Users\nanashi\Desktop\aaa -Force}
C:\Users\nanashi\Desktop\aaa\bbb
C:\Users\nanashi\Desktop\aaa\ccc
C:\Users\nanashi\Desktop\aaa\eee
C:\Users\nanashi\Desktop\aaa\fff
C:\Users\nanashi\Desktop\aaa\eee\eee01.txt
C:\Users\nanashi\Desktop\aaa\eee\eee02.txt
C:\Users\nanashi\Desktop\aaa\fff\fff01.txt
C:\Users\nanashi\Desktop\aaa\fff\fff02.txt
できました。あとはいらなくなった空のフォルダを消すだけです。
ワンライナーでも書けて目的も達成できるんですが。この場合ソースパスとターゲットパスを同じにできませんというエラーがでてしまいます。元々 aaa 直下にフォルダがあり、同じフォルダに動かそうとしたせいですね。
このようなコードをよく使うんですがいつもエラーを無視しています。エラーを回避するために複雑なコードを書きたくないからです。もしエラーを簡単に消せる方法があったら教えてください。
コード自体になにか問題があれば合わせて教えてください。
あの。大変申し訳ありません。書き込んですぐなんですけど。2文字追加するだけでいけました・・・。
ls C:\Users\nanashi\Desktop\aaa\* -r | ?{$_.PSisContainer} | %{mi $_.FullName C:\Users\nanashi\Desktop\aaa -Force}
あるフォルダに
Movie_00_(<肝心のファイル名>).mp3
Movie_01_(<肝心のファイル名>).mp3
Movie_02_(<肝心のファイル名>).mp3
以下続く...
というファイルがあって
このフォルダで
Get-ChildItem | ForEach-Object {Rename-Item -Path $_ -NewName $_.Name.Remove(0, 1)}
これを実行すると
一回目はファイル名の最初3文字が消えて、ie_00_(<肝心のファイル名>).mp3 に
この状態で再度実行すると今度は一文字だけ消えて、e_00_(<肝心のファイル名>).mp3
この状態で再度実行すると今度は二文字消えて、00_(<肝心のファイル名>).mp3
ってなっちゃうんですがなぜでしょうか。
以前この手のファイル名置換はうまくできてたんですけど。
すごくあほな勘違いかミスだと思うのですが
もうずっと考えてもわからないので助けてください。
>>669 ですが、
Get-ChildItem Movie* としてフィルタをかけた状態でやったらうまくいきました。
どうして? Forループの途中で名前が変わってるのがミソ
ループの列挙子が_A〜Za〜zの順にファイルをピックアップする
Mで始まるファイル名を一通り拾って置換した後
置換後の名前はoで始まるから同じループ内で再度ピックアップされてしまう
M, o, v まで文字コード昇順に並んでるから1回のループで1文字ずつ3回置換されてる
次のiはvよりも若い文字だからもう走査済みなのでそこで止まる
おー、そういうことなのか
ありがとう。
単純にファイルのリストを作って次のループに渡すんじゃないのね、
今後もはまることありそうだわ。
一つのコマンド処理が終わるのを待ってパイプで受け渡してたら
メモリと時間がうなぎのぼりに増えていく
オブジェクトを渡せるメリットとのトレードオフなので素人ではないよ
いやむしろそれこそがパイプラインだろと
一体誰が素人って話なんだ
PwerShellをbuildしようとしてるんだけど
DotNetEventingStrings
がコンテキストに含まれていないと叱られます
これはどのモジュールに含まれてるんでしょうか?
共有フォルダ(\\192.168.0.1\hoge)上でpower shellを動かしたいんだけど
証明書なしだから実行出来ないというエラーが出てしまう
オレオレ証明書での実行の仕方もいまいちわからんのですが
参考なるところ教えてくれませんか
社内で使うとかで、makecert.exeとかは無い状態です
助けてお願い
実行ポリシーは何にセットされてるの?
変えて良いなら変えるのが手っ取り早いと思うけど
リモートホスト上で走らせたいのか、クライアント上で走らせたいのか?リモートなら当然認証や権限の問題を適切に処理せんとどうしようもない
すみません
調べても分からなかったのでご教示ください
標準出力をパイプに渡してエラーのみをファイルにリダイレクトということはできるのでしょうか
2> file 1| command
にすればいいんでしょうか?
よく意味がわからない
パイプはエラーを通さない。通すのは標準出力のみ
エラーをファイルにリダイレクトするには
command 2>a.txt
のようにする
powershellでcpu100%になれば下げたり何かのタスク終了したりできますか?
たぶんそのような機能はあるはずだが
Windows でその種の機能って実用的な動きしないこと多いしな
CPU100%だからpowershell動けないんじゃw
ありがとう。なんかアプリでありそうですね。
電源管理で100%押さえれますわ。
60%とかにしときました。
GPOの設定を自動化したいんですけどGPMCとかいうの入れずにやる方法ありませんか?
ポリシーってのはセキュリティ周りのを除けば基本的にレジストリの設定集と思えばいい
逆説的に言えばポリシーで設定されるレジストリ値を設定してしまえばいいだけ
ドメインポリシーみたいな強制性が欲しいとか
そういう管理面での要件があるなら別だけどパンピーなら
該当するレジストリを設定すりゃ間に合うはず
もちろんすべてがすべてそうという訳じゃないが
powershell v2でテキストの文字列置換する方法教えて
(gc a.txt).replace("aaa","bbb") |Out-File b.txt
ってやるとv3では通るんだけどv2だとエラーになっちゃいました
>>697
ありがとうございます。
やってみたのですが[IO:file]という型がありませんとか表示されちゃいました
因みにosはwindows2008r2です すみません頭に[System.IO.file]とやったらいけました
powershell2.0で教えてください
単純にフォルダをネットワークドライブ配下に移動したいのですがいい方法はありませんでしょうか
何故かファイル単位だとうまくいきます
↓な感じです
Move-Item "元ファイル" -destination \\server\log
3.0だと同じ処理をやってもうまくいくのに何故2.0はこんな簡単なことも出来ないのか半泣き状態です
>>700
どんなエラーが出るとか、どういう結果になったとか書くとアドバイスもらいやすいよ
2.0でも Move-Item -Path "元フォルダ" -Destination \\server\log でOKなはずだけど
Windows Server 2008でもWindows Management Framework 3.0でpowershell 3.0が使えるようになるけど、サーバだと他の影響が怖くて変更しにくいのかな? -Forceつけてダメだったら
Move-Itemあきらめて
PS> Copy-Item "元ファイル" -destination \\server\log\ -recurse
PS> Remove-Item "元ファイル" -recurse
かな
原因は突き止めた方がいいと思うけど
PS> gi "元ファイル" | % {$_.MoveTo(“\\server\log\“)}
でもダメなんだろうなあ
>>702
スマホから書いたら全角混じっちゃった
失礼 >>701-703
ありがとうございます
エラー内容については仰るとおりです
失礼いたしました
なおエラーは↓が出ていました
Move-Item:ソースとターゲットのパスは同一のルートを持たなければなりません。[移動]操作はボリューム間で行えません。
個人的にはpowershellv3を入れないのですが商用サーバーということもありそうも行かず…
頂いた内容でまず試してみます >>702
試してみたところcopy-item、remove-itemでうまくいきました!
何故move-item出来ないのか謎ですが一旦これでいきます
ありがとうございました スクリプトで
VPNセッションを張って、opensshでLinuxサーバーにログインしたいんですが、クレデンシャル情報ってどう引き渡せば良いですかね
コマンドプロンプトでcopy /b file1 + file2 out
でバイナリ結合できるけど
Get-Contentではどう頑張ってもできない?
結局cmd /c copy 〜 でやってる
copy xcopyをpowershellで完全に置き換えられるレベルまでMSには頑張って欲しかったなぁ
xcopyで出来るものならxcopy使うけど
なんたってrobocopyとは速さが桁で違ってて比べ物にならない
ファイルコピーに野良ライブラリーは使いたくない
コマンドプロンプトからの移行をMSが本気で考えていたならファイルコピー機能はまず最初に実装すべきなのに
robocopyをPowershellから実行できるから別にいいや
リッチなコピーコマンドをまた覚えるのも面倒だし
>>715
「コマンドプロンプトの外部コマンド」じゃなくて「OSに標準搭載されてるコンソールアプリ」だと考えろ
Get-Command xcopyやGet-Command robocopyを実行するとCommandTypeがApplicationになってるんだし
PowerShellは名前の通りシェルであって
シェルからアプリを起動するのを躊躇する理由は全くない >>712
>なんたってrobocopyとは速さが桁で違ってて比べ物にならない
xcopy遅いですよね 名前にブラケットとか入ってるディレクトリをカレントディレクトリにして
適当なファイルにGet-Item -LiteralPath hogeとかするとObjectNotFoundになる。
内部で絶対パスを生成するときにカレントディレクトリのパスをエスケープしているようだ。
LiteralPath使ってんだから勝手にエスケープすんなやアホか。
新しいクロスプラットフォームの PowerShell をお試しください
.net特化型スクリプト言語、って割りきってるのかなとも思ったけど
どうも開発陣はこの言語構文が優れているという信念を持ってるらしい
Python と似た芳ばしさを感じる
あんまり近寄りたくない
7って管理者モードで起動しているかいないかがコンソールウィンドウのタイトルで分からなくなってる?
7.0.0はMicrosoft Storeでのリリースはなしか
7.0.0-rc.3ではGitHubにあった.msixもない
フォルダ内のjpgの画像データを一括でリサイズするとき、拡張子をjpegではなくjpgのままで変換したいのですが可能なのでしょうか
>>726
UNIXシェルの構文はもっと糞だけどな >>730
正直、余計なことしてない分シェルとしてはUnix シェルの方が使いやすい
言語として貧弱なのはあくまでもシェルが本文と割りきってるからで
言語機能を強化するためにシェルとして分かりにくくなってるPowerShell よりもツールとしては百億倍合理的 echoの仕様すら統一できてないくせに合理的だの使いやすいだの
なんのギャグやら
PowerShell のように奇妙キテレツな挙動じゃないからなそこまで実害がないもの
言語としての機能はPowerShell の方が上だよ
でも単純にShell として考えた場合の実用性はbashどころかcshにも劣る
まあ裏返せばCLIの使い勝手しか改善のしようがなくなっちゃっただけなんだけどね
多分10年20年先も*shの読みづらさは変わらんだろうし
読みづらさなんて最初だけ
Unix の世界は慣れれば同じルールで一貫してやっていけるから楽
PowerShell なんてパイプラインの挙動がオブジェクトや文脈で変わりまくって、かなりの経験者でも動かしてみるまでどうなるか予想できないだろ?
Unix ならしばらく勉強すればログから複雑な条件で問題行を抽出するとかできるようになる
同じ期間PowerShell 学習した奴が同じことしようとしたら、自動書式化回避するために丸一日潰すことになる
Unix でせっかく克服した
Multicsのバッドプラクティスを
ご丁寧に復活させようとしてるのがWindows だろ
ということは、もう一回りすれば、良い物ができるかもしれないのだな
トンプソンみたいな人がいれば...だが
> PowerShell なんてパイプラインの挙動がオブジェクトや文脈で変わりまくって
意味が分からないんで解説お願い
>>738
わからないから使えてる(気がしてる)んだろう
>>739
そういうのは挙動に一貫性があって言えること
慣れたところでその慣れが極めて局所的にしか役に立たないんじゃたいして役に立たない
MSの製品はアプリもAPI もみんなそう デバッグの第一歩がいきなりログ解析じゃ話にならない・・・原始的すぎる・・・
>>742
結局丸一日考えてその程度のことしか言えないのか >>736
> PowerShell なんてパイプラインの挙動がオブジェクトや文脈で変わりまくって
具体例よろしく
まあ笑える例しか出てこないと思うけどw >>740
一貫性がないのはUNIXシェルだろ
偉そうなこと言うのはechoの挙動くらい統一してからにしろ
何のためのPOSIXなのやら >>744
昔外部コマンドをパイプでつないだらバイナリデータが化けてイーッてなった覚えがあるんだけど
あれからだいぶバージョン上がったが、そろそろ直ってる? PowerShellでパイプに流せるのはテキストかオブジェクト
バイナリ流すとテキストだと思ってUnicodeに変換しちゃうらしい
外部コマンド呼んでstderrになんか出るとエラーになるのマジでうざい
cmdletちゃうんやからLASTEXITCODEだけで判断せえよ
stderrは乱用されすぎなんだよ
PowerShellのWrite-VerboseやWrite-Debugはもっと評価されるべき
Windows10にPowerShell7入れたんだがGet-Clipboardが
The term 'Get-Clipboard' is not recognized...
ってなるんだけどなんで?
ちなみにSet-Clipboardは使えた
なんでだろ
gmo "Microsoft.PowerShell.Management" | % exportedcommands
の出力にGet-Clipboardあるか探してみて
なんか知らんが今やったら使えた
>>751 のコマンド入れたから?
できなかった時から起動しっぱなしのシェルだからそれぐらいしか考えられない & hogehoge.exe 2> "hoge[1].txt"
なんてことをたいんだけど、これだとブラケットをワイルドカード展開しようとしてエラーになる。
[WildcardPattern]::Escape()使うとエラーにはならないけどファイル名にバッククォートが入る。
どうすればいいですか?
もしくはstdoutは捨ててstderrだけパイプラインに流す方法とかありますか?
(& hoge.exe 2>&1|?{$_ -is [System.Management.Automation.ErrorRecord]}).Exception|Out-File -LiteralPath 'a[1].txt'
でできた
6.0以降はWindows powerShellじゃないんだが、このスレで話してもいいの?
外部コマンドの出力をパイプラインでつないでごにょごにょしようとしたら
外部コマンドが終わらないと次の処理に行かないんだが、どういうこと?
MS-DOSに先祖返りしたんか?
7.0.1が出て.appxが復活したもののなぜかPreview扱いになってるな
Windows TerminalでもPreviewとみなされてる(アイコンがPreview版)
ググると文字列は+で繋げるとありますが、
$word="坂本"
echo $word+"竜馬"
だと坂本+竜馬と表示されるのですが?
$word="坂本"
echo $word"竜馬"
だと坂本龍馬と表示される。
>>764
ありがとうございます。
分かりました。 >>763
PowerShell流にやるならechoはいらないので
$word="坂本"
echo $word+"竜馬"
としないで
$word="坂本"
$word+"竜馬"
とすれば望まれた結果になりますよ >>766
関数でも最後ならreturn要らないの? >>767
要らない
他の言語のように return $a とか書けるけど
$a
return
と同じ意味 PSでは代入などの文にせずに式を書くだけでコンソールに出るから基本echoは要らない
echoにはおそらく互換性のために、式モードと引数モードというのがあって、引数モードだと引用符が要らない
最初から
echo 坂本竜馬
と書ける
式モードにするなら
echo ($word+"竜馬")
のようにかっこで囲む
>関数でも最後ならreturn要らないの?
最後だけでなく途中に書いた式による出力も全部戻り値としてパイプに渡される
PSにおいてreturnは戻り値を返すというより関数を抜ける役割で使うもの
>>763
で、簡単じゃんと思ってディレクトリもこれで繋がると思ってみたり
ディレクトリはJoin-Path使う罠 7.0.2, 6.2.6が出た
7.0.2の.msixは相変わらずPreview版扱い
Previewになってるのは7.1で修正するらしい