【最強CUI】PowerShell -Part 2 [無断転載禁止]©2ch.net

■ このスレッドは過去ログ倉庫に格納されています
2016/11/26(土) 06:30:02.67ID:pZYy6q7Y
前スレ
【最強CUI】PowerShell -Part 1
http://echo.2ch.net/test/read.cgi/tech/1378978504/
2018/02/15(木) 17:07:26.96ID:4lKXUWzM
Selenium WebDriver は、PowerShell では出来ない

使えるプログラム言語は、Java/C#/Ruby/Python/Javascript
464デフォルトの名無しさん
垢版 |
2018/02/15(木) 18:02:19.40ID:ZXhM7ba9
出来ますよ
465デフォルトの名無しさん
垢版 |
2018/02/15(木) 18:18:56.65ID:ZXhM7ba9
>>463
それ、C#と書いてあるけど
.NETと解釈したらいいんですよ
それだけ。
それが.NETの良いところ
2018/02/16(金) 07:20:11.08ID:shLmPi2M
Win7 SP1 PowerShell 2.0の環境に隔離されたんだけどPSでGUIやるとしたら.NET 4.0のWinFormsが妥当?
セルフホストのHttpServerがあるならばブラウザアプリにするんだけどPS 2.0 .NET 4.0だとまだないよね
2018/02/16(金) 15:20:24.69ID:nkfY21W7
Windows7 SP1なら https://github.com/PowerShell/PowerShell/releases から
2018/01/25公開のPowerShell Core 6.0.1を入手し、今の内に慣れておくほうがいいのでは?
468デフォルトの名無しさん
垢版 |
2018/02/16(金) 16:51:14.69ID:jq0LJPC+
>>467
『隔離された』と書いてあるんで
そうしなくてもできないという話じゃないの?
2018/02/16(金) 19:11:11.01ID:pw8u3FlN
そうです
ネットは監視されてます
インストールも自由にできません
470デフォルトの名無しさん
垢版 |
2018/02/16(金) 19:31:53.38ID:jq0LJPC+
しかし、今後のネットなどを考えると
新たな発想の仕組みが出現してこないと
不自由でしかたないね。
いたちごっこの繰り返しだもんね。
2018/02/16(金) 22:10:13.50ID:pdOGHn5a
リモートで別のPCを操作したいという要求がある限り穴は無くならないのでは?
472デフォルトの名無しさん
垢版 |
2018/02/16(金) 22:42:52.85ID:vp1KbUn5
今のところ、ネットがある限り穴はあるというところ。
でも今後ないと困るわけだからね〜。

それに対応する暗号利用技術は考えられているんだが
まだ実用化されないし。
といっても暗号化も対処技術に他ならないしね〜〜
2018/02/16(金) 22:57:24.63ID:TT/12OsV
>>448
してる決まってるだろ。いくらなんでも素人杉。
474デフォルトの名無しさん
垢版 |
2018/02/17(土) 01:10:35.41ID:YxQ+FKPw
わたし448じゃないけど、基本してないでしょ。
2018/02/17(土) 09:26:10.93ID:RP1Lckbc
GUIだんだんわかってきた
WPFが動くからFormsよりWPF使うほうが簡単だった
別ファイルにXAMLとViewMode(C#)を書いてXamlReaderでパース、Add-Type
しかし今のところPowerShellスクリプトの出番がほとんどない
PSCustomObjectをバインドできれば使えるのかな
476デフォルトの名無しさん
垢版 |
2018/02/17(土) 09:31:46.64ID:AgYT9x+M
>>475
私は、WPF利用して逆にPowerShellの出番がガンガン増えてるよ〜。
2018/02/17(土) 14:55:08.94ID:O2aJXn1j
.NET Coreには、WPF無いけどPowerShell CoreからWPF使えるのかな?
2018/02/17(土) 15:32:09.98ID:tJC3jvlA
んなわけない
2018/02/17(土) 16:33:07.35ID:/8k93ROr
>>475
簡単なGUIならXAMLもPowerShellに書いちゃえばいいじゃん?
480デフォルトの名無しさん
垢版 |
2018/02/18(日) 00:25:57.67ID:mfQi5O1f
Visual StudioでWPF設計して
そのxamlをそのまま読みこんでPowerShellの表示に使えるように
PowerShell関数作ってます。
結構簡単に出来るよ
2018/02/18(日) 07:28:07.73ID:Stb7rhur
>>480
エライエライ
2018/02/18(日) 21:06:46.31ID:HOomNEjj
PowerShellで作る時に、使う最強のエディタは?
2018/02/18(日) 22:10:00.84ID:JlUJeRgg
VSCode
2018/02/19(月) 00:49:35.13ID:PsquRqu/
edlin
2018/02/19(月) 05:38:51.91ID:p/IhV2LV
>>482
VSCodeが決定版
やっぱ同じMS製だし
他言語でも使える
2018/02/21(水) 21:50:44.89ID:sytXW6IH
excelの選択範囲をpowershellに渡す方法教えて
ファイルに出力→powershellサブプロセス
はダサいから無しで
487デフォルトの名無しさん
垢版 |
2018/02/22(木) 03:26:54.69ID:hk+HnqcW
$excel=New-Object -ComObject Excel.Application
$excel.Visible=$true
$wokbook=$excel.workbooks.open("なんとか.xlsx")
$woksheet=$wokbook.ActiveSheet
$actCells=$excel.Selection
488デフォルトの名無しさん
垢版 |
2018/02/22(木) 03:28:18.65ID:hk+HnqcW
要は、最後の1行
$actCells=$excel.Selection
2018/02/24(土) 01:27:05.92ID:u/AYofsf
そういうのでよく使うのはGetObjectの方だと思う
2018/02/24(土) 02:25:42.58ID:EfAIzsYg
エクセルついでに、
csvをエクセルで開いて配列に一気に取り込んで、それをxlsx形式で新規保存する方法教えて。
491デフォルトの名無しさん
垢版 |
2018/02/24(土) 05:43:27.81ID:4C8nRMYU
$excel=New-Object -ComObject Excel.Application
$excel.DisplayAlerts=$false
$workbook=$excel.workbooks.open(”入力path\なんとか.csv")
$workbook.SaveAs("保存path\かんとか.xlsx",51)
$workbook.Close()
$excel.Quit()
2018/02/24(土) 09:43:41.67ID:tzORDq38
ありがとう。
エクセルで開くときはcsv importみたいなコマンドレットは必要ないのね。その辺が調べてもよく分からなかった。

なお、配列にはデータ取り込んでる?
@()に入れる方法がよく分からん。
vbsだとarray=sheet.usedrange でできるけど。
493デフォルトの名無しさん
垢版 |
2018/02/24(土) 10:16:12.10ID:4C8nRMYU
>>492
ごめん、いま明日の引っ越し準備で
対応できない。
2018/02/24(土) 12:22:39.31ID:NyTmnWgI
$array = $sheet.UsedRange.Value2
で良いんじゃね
2018/02/24(土) 15:03:06.06ID:EfAIzsYg
なるほど。
powershell だからパイプライン使うイメージだったけど、エクセル操作ではあまり使えない感じなんだね。
2018/02/24(土) 15:07:47.88ID:9oN2QzaC
20年近く前にvbscriptで散々やったものを今必死にPowerShellで再現してる最中なのか。
2018/02/24(土) 22:59:13.75ID:EfAIzsYg
ほんとそんな感じ。
サーバー管理するわけでもないなら、powershell そんなに覚える必要ないかな。ただパイプラインは面白いと思う
2018/02/25(日) 00:32:11.83ID:01COGLgI
ファイル操作には便利だよ
単機能のツール探すよりPSで書いた方が早いこと多い
2018/02/25(日) 01:39:02.81ID:pcyqC+jB
PowerShell より複雑なものは、Ruby を使え

Rubyから、Excel を扱うライブラリも、色々あるみたい
2018/02/25(日) 01:40:14.58ID:bSC8YYTG
>>499
Excelならc#で十分だわ
2018/02/25(日) 01:46:43.42ID:xNv2PYt4
pythonスレやpowershellスレでひたすらrubyすすめてくるキチガイはなんなんだw
502デフォルトの名無しさん
垢版 |
2018/02/25(日) 03:34:56.38ID:X5QEzlQF
>>499
COM経由で一緒
2018/02/25(日) 04:58:27.12ID:5ohi2TD0
なんかrubyはずっといる
2018/02/25(日) 04:58:51.59ID:5ohi2TD0
>>500
VBAだろ
2018/02/25(日) 06:53:28.67ID:579ZQdUK
>>500
System.Runtime.InteropServices.Marshal.ReleaseComObject( ) 地獄に落ちてもいいならな

MSもMicrosoft.Office.Interop.Excelはアンマネージドなリソース使うんだからDisposeを真面目に実装しとけよ
2018/02/25(日) 07:36:24.71ID:xNv2PYt4
そうじゃなくて今はClosedXMLとかを使うんじゃないの
2018/02/25(日) 07:44:46.15ID:bSC8YYTG
>>505
いつの時代の話だよ
2018/02/25(日) 08:14:51.73ID:/V/K592r
客先で他になんにもないときにめちゃ助かる
VBAも悪くないけど基本ライブラリしょぼいし別プロセス連携とかオブジェクト指向やりにくいから

>>505
Book.CloseとかApp.Quitとか要点さえ守ればCOMラッパーが参照カウントを処理してくれるからReleaseComObjectは不要
2018/02/25(日) 08:39:48.35ID:RKRNLmY8
ただ本音を言うとCOMはもう直接触りたくない
裏方に徹してくれる分にはいいんだけど

そもそもOfficeが.NETのプラットフォームから逸脱してるのが面倒の素
2018/02/25(日) 09:25:49.90ID:Ydc/tL+D
データ取り込み->OleDb
帳票出力->サードパーティのマネージドライブラリ
操作性拡張->VBA

.NET相互運用は需要がない
2018/02/25(日) 16:14:29.85ID:4dYhkUpy
>>507-508
> Book.CloseとかApp.Quitとか要点さえ守ればCOMラッパーが参照カウントを処理してくれるからReleaseComObjectは不要
マジで言ってるの?
それとも最近便利な(まともな)ラッパーでもできたの?
2018/02/25(日) 16:45:57.41ID:f0GbsyKa
ラッパーなんてあるの?
webに転がってるpowershellの糞コードはまともに開放してないし
powershellで気を付けるレベルじゃどうやっても開放漏れは起こる
潔癖ならCOMと親和性の高いwshで処理したらいいし
大抵の人はEXCEL.EXEが残らなければOKって考えでしょ
2018/02/25(日) 19:36:34.84ID:Ydc/tL+D
逆に聞きたいんだが適切にCloseやQuitしててもリソースリークするエビデンスってある?
2018/02/25(日) 19:37:48.11ID:riORzo3z
>>511
NPOIとかClosedXMLすら使ったことないん?
2018/02/25(日) 20:06:18.82ID:Ydc/tL+D
そもそもエクセルプロセスが生きてる以外にリーク判定ってどうやってんだ?
2018/02/25(日) 23:21:13.29ID:97AlcoLv
質問です。EXCELファイル内のマクロコードをGREP検索したいのですが
powershellからそのようなことは出来るのでしょうか?
(powershell以外の方法でも構いません)
2018/02/26(月) 08:48:04.46ID:0MjsGOBH
>>513
C# の話な

> 逆に聞きたいんだが適切にCloseやQuitしててもリソースリークするエビデンスってある?
適切の意味にもよるけどシートを参照したままApplication.Quit() してもリソースリークするって言うのはググれば出てくる
(これはVB.NETの例だけど)
https://social.msdn.microsoft.com/Forums/ja-JP/3a296f83-4a49-4561-a735-570aa7430874/ecxel?forum=vbgeneralja

>>514
COMの話であることも理解できないアホは絡んでくるなよ
2018/02/26(月) 08:55:33.76ID:qQ1Da7Hp
>>517
どうも日本語が不自由なようだ
2018/02/26(月) 09:29:44.47ID:0MjsGOBH
>>518
お前が誰か知らんけどそんなレスしかできないなら黙ってなよ w
2018/02/26(月) 09:57:08.97ID:MMVJYAud
>>519
涙拭けよw
2018/02/26(月) 10:12:54.85ID:0MjsGOBH
なんだ、無能の煽りかよ
2018/02/26(月) 12:17:43.07ID:7zf74qFu
>>521
顔真っ赤にしてどうした?w
2018/02/26(月) 12:21:47.40ID:aBQXIVru
ゆとりはCOMやオブジェクト思考を理解できない。
2018/02/26(月) 12:29:53.91ID:LisqF3+Y
いまどきCOMとかwww
2018/02/26(月) 12:32:03.28ID:aBQXIVru
このとおり。COMが何かすら理解してない様子。
2018/02/26(月) 12:49:39.49ID:K3pn9bD4
今は2018年だった気がするが
2018/02/26(月) 13:03:41.88ID:byvTlEgJ
>>517
エビデンスって言うには弱いな
コードの断片だけ見せて開放されないんですって言ってる人が居たってだけで
それにこれたぶんGC回ったら回収されるパターンでしょ
2018/02/26(月) 13:18:51.36ID:aBQXIVru
MSのメモリリークのバグなんて昔から何度もあったのに。MSも随分と信用を得たものだ。
2018/02/26(月) 13:26:17.87ID:zI4VKzz4
まあ今時COMって言うのは間違ってはないとは思うがCOMの話してるのにNPOIとかClosedXMLととか言い出す>>514が頓珍漢であることは変わらない
2018/02/26(月) 13:33:29.92ID:aBQXIVru
VS2017にATLついてる。なぜならMSが必要だから。COMなしではWindowsは動かない基盤技術。

おまえらの2chブラウザも動かなくなる。
2018/02/26(月) 15:06:05.67ID:tmFMcABi
流れを見ると>>500のレスを>>505が勝手にCOMの話と勘違いしたからそもそも話しがおかしくなってるんだと思うけど
どっちにしろたいした話もできてないからもう終わりでよくね
2018/02/26(月) 15:21:15.75ID:9PwnP/L5
ClosedXMLはExcelを操作するんじゃなくてExcelファイルを操作するライブラリだしww
てかいつまで粘着するの?
2018/02/26(月) 17:32:43.42ID:JDadgspp
COMの話題でどっと混む
2018/02/26(月) 18:04:10.90ID:XspdtcWH
エクセルでcsvを開いて、名前変えてエクセルファイルとして保存したいんだけど、
c:/test.csv
から
c:/test_add.xlsx
って感じに。
このとき、split-path $_ -parent + "/" + $.basename + "_add.xlsx"
みたいな書き方してるんだけど、もっとカッコいい良い書き方ある?
2018/02/26(月) 20:02:07.45ID:tmFMcABi
>>534
かっこいいかは分からんけどjoin-path使ったり
Join-Path $_.Directory ($_.BaseName + "_add.xlsx")

置換したり
$_.FullName -replace "\.csv$", "_add.xlsx"

単に文字列内で展開してもいいだろうし
"$($_.Directory)\$($_.BaseName)_add.xlsx"
2018/02/26(月) 23:11:59.96ID:6edExPT+
>>535
ありがとうございます。
さらっと3通り出るのすごい。

joinがpowershell 使ってる感あって好き、けど文字列内の$$もいいな
2018/02/26(月) 23:14:27.61ID:cmg78qzM
PowerShellで画面の文字拡大率を変更する事は可能?
ノートPC使っていると、150%とか100%を変えたい時があるが
いちいちGUIで変更するのが大変
2018/02/27(火) 10:39:21.42ID:OXeiIV2T
PowerShell.exeのショートカット2つ作ってプロパティで色やらフォントサイズやらを別々に設定して
好きな方を起動するというのはできる
2018/02/27(火) 14:22:33.25ID:CzY5WQW+
顔を画面に近づけるだけだろ。どんだけデブなんだよ。
2018/02/28(水) 14:27:13.44ID:wxg4ntZg
文字の大きさなんて超基本なのに
その煽りはないわ
2018/02/28(水) 21:26:18.73ID:XB4appM3
好きに変更すりゃいいじゃねーか。GUIで変更は嫌だとか、キーに割り当てるのも嫌だとか、
顔近づけるのも嫌だとか、ほんとデブは馬鹿で横着だからヤダね。

メイドでも雇って変更してもらえや。
2018/02/28(水) 21:35:16.05ID:Gdb2LJhC
この句読点は無視でいいよ
543デフォルトの名無しさん
垢版 |
2018/02/28(水) 21:39:00.90ID:XB4appM3
句読点の打ち方が分からない低学歴アピール乙。
544デフォルトの名無しさん
垢版 |
2018/02/28(水) 22:44:45.43ID:updNaSP6
>>537 で言っているのは、何の画面のこと?
powershell.exeのコマンド画面も
powershell_iseのエディターも既定値設定できるんで
なんの話か理解できなくて。
545544
垢版 |
2018/02/28(水) 22:53:58.42ID:updNaSP6
自分の文章理解力がなかった
Windowsの画面そのもののフォントサイズを
変更したいという話だったのね。
546デフォルトの名無しさん
垢版 |
2018/02/28(水) 23:12:12.84ID:XB4appM3
GUIで設定するのも面倒、句読点を打つのも面倒。脳に障害があるレベルだな。

だが安心してください。Windowsには障碍者モードが実装されてます。
2018/03/01(木) 01:21:24.03ID:nHL6zjeN
まあ、PowerShellというよりもWindowsコンソールが機能不足かつ分かりづらいのは確か
ただ、フォントサイズくらいは変えられる
2018/03/01(木) 01:23:11.44ID:0hekOGPH
PPMとか生成したバイナリデータをリダイレクトで保存するのは難しいのかな
cmdはできるのに
2018/03/01(木) 10:56:37.02ID:tP9VZ2s0
句読点の付け方は別に間違っちゃいないけど、2chでそこまでしっかり打つのは少数派だから
ちょっと異様に見えるよ
550デフォルトの名無しさん
垢版 |
2018/03/01(木) 11:57:54.51ID:lQ3pJcx7
単純に低学歴、低知能は句読点を打たない。
文章や論文を書く習慣がないし本も全く読まないから句読点がないことに違和感がない。つまり馬鹿。

ひろゆきすら打つ。くだらない知ったかして2ch素人にもほどがあるな。
しかも句読点があると異様だとかもはや脳みそに蛆でも沸いてるレベル。もはや日本人じゃないな。

1 名前:ひろゆき@どうやら管理人 ★[] 投稿日:2014/04/09(水) 14:47:55.24 ID:???
なんらかの不具合を見つけたら、
報告するスレッド。

118 名前:ひろゆき@どうやら管理人 ★[] 投稿日:2014/04/12(土) 02:48:58.08 ID:???
>>25
どうぞ、どうぞ。
2018/03/01(木) 12:37:08.99ID:tP9VZ2s0
ひろゆきも打つからなんだっつーの
本と2ch(というかメールやブログのコメントもだけど)は大きく違う
ソフトによって画面端での自動の改行がさされたりされなかったりするから、長い行はあまり書かない
「。」の代わりに改行で済ますように変化してる
行末に「。」を付けるのはかなり少数派だよ
552デフォルトの名無しさん
垢版 |
2018/03/01(木) 13:38:12.57ID:Bn8v5XdY
>>550
そういう見方もあるだろうが
昔に戻ると、句読点は必須ではなく
文章に不慣れな人達のために使われるようになったそうで、
いまでいう高学歴というような人に対しては使わないもの
だったそうだ。
そのために、今でも表彰状などには句読点は一切使われない。

ちなみに、句読点が一般的に使われるようになったのは、
明治半ば以降だそうだ。
2018/03/01(木) 15:34:24.24ID:mJRDcTgH
読みづらくなきゃなんでもいいと思うよ
クッソ読みづらくても句読点のあるなしにしか拘らん方が問題ある
読みやすい文の組み立てを心がければいいでしょう
554デフォルトの名無しさん
垢版 |
2018/03/01(木) 15:34:48.45ID:Bn8v5XdY
感謝状、招待状等あえて句読点をつけない文章の共通点とは?
https://woman.mynavi.jp/article/150205-71/

かつて、句読点を付けるのは『相手を見下す』
要は、句読点がないと文章も読めないだろうと相手を見なすことに
なることだったようだ。

ま、当時は漢字の利用頻度も高く、漢字ひらがな混じりでも
読みやすかったのでしょう。今はひらがななどの割合が高いので
やはり適切に句読点を使う必要あるんでしょうね。
2018/03/01(木) 15:40:17.42ID:mJRDcTgH
長文でひらがな比率高いと文の区切りが分からなくなりますからね。
2018/03/01(木) 19:01:36.71ID:5P8YUW6k
>>550
句読点の、打ち方が下手な香具師もよく、見かける
2018/03/01(木) 19:41:09.89ID:Bj3H1eP5
単に句読点はこのスレで低レベルな煽りを繰り返してるキチガイの特徴ってことだろ
IDかわってもすぐわかる
2018/03/01(木) 19:50:29.18ID:dLJOyeYF
句読点を適切に付与するスクリプト書いてよ
2018/03/01(木) 20:40:16.88ID:yqOkTTLk
powershellだけでプロジェクト組むとしたらどういうフォルダ構造にする?
2018/03/01(木) 21:33:08.36ID:cFY6likq
中東あたりだと母音を省略してしまうんだよね?
2018/03/02(金) 12:53:13.17ID:Bue9fMqJ
煽りうざいから話題換えよう

>>559
良い質問な気がする

ただオレ自身は単ファイルで済むバッチ
みたいなのを書くのがほとんどだから

もし本格的なプロジェクトのフォルダ構成を組むなら
JavaとかRubyとか他言語の構成をマネするかな
2018/03/03(土) 09:41:45.03ID:7F+xAEZY
PSCustomObjectで特定のinterfaceを実装したいんだがやりかたわからん

public interface IFoo {
int Bar(int x);
}

public static class Hoge {
public static void Fuga(IFoo foo) {
Console.WriteLine(foo.Bar(100));
}

$foo = new-object pscustomobject |
add-member -passthru -membertype scriptmethod -name Bar -value { param($p)
return 200 }

[Hoge]::Fuga($foo)

こういうことしたい
2018/03/03(土) 22:48:42.40ID:ApJ804E1
GoやTypeScriptじゃないんだからメソッドを持ってるからってinterfaceを実装してることにはならんよ
素直にIFooを実装するclassを定義すれば?
■ このスレッドは過去ログ倉庫に格納されています
5ちゃんねるの広告が気に入らない場合は、こちらをクリックしてください。

ニューススポーツなんでも実況