【最強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/05/24(木) 19:37:16.12ID:8RmhyhjF
そういう設定なんだなというのは皆わかった上でディスカッションしてる
なので野暮なツッコミは無しにしようや
2018/05/24(木) 19:58:22.10ID:HJmOkmLD
勉強とは再発明することだと思うんがなあ
2018/05/24(木) 21:09:40.32ID:zQgi4Vqc
>>735
今はデータをUSBで他のPCに移してから処理してる。
制御PCでやりたい理由は、USBはパスワード付きっていうのもあって面倒で、しかも常に最新の情報を求められるため日に数回USBで出し入れすることになるのでより面倒。
それが毎日となるとめちゃくちゃ面倒。
ということで不慣れなpowershell でやろうとした次第です。
2018/05/24(木) 22:23:06.92ID:A0AqRoYu
別PCでC#の解析用アセンブリ作ってPowerShellから呼び出したらいいんじゃないの
2018/05/24(木) 22:34:04.69ID:JOD0E1R+
ネットも禁止な所?
2018/05/24(木) 22:42:20.58ID:OVWSg8Eh
オフラインです。C♯は難しそうなので。

すみません、私事を語り過ぎました。元の話題に戻ってどうぞ
2018/05/24(木) 22:53:30.12ID:6yspu/tD
死亡事故が起こるようなマシンだろ
俺なら通常はネットから切り離しとくわ
2018/05/25(金) 02:05:25.85ID:gztHcn54
>>742
オフラインって書いてますやん
744デフォルトの名無しさん
垢版 |
2018/05/25(金) 03:37:02.75ID:JRXZZDGl
会話がかみ合ってないな
頭悪そう
2018/05/25(金) 03:58:22.29ID:cDmsKy0H
いや現実の問題設定は良い刺激になったよ
そういうのないと同じ話題がループしちゃうし
2018/05/25(金) 06:29:46.18ID:zDcEhAN3
そのPCで処理しても結局USBで持っていかないと駄目なんじゃ
2018/05/26(土) 18:35:06.63ID:2fyQupuv
AddTypeでNuGet Packageを参照に追加できれば便利だと思うんだがなぜないんだろ
いちいちpackageダウンロードしてzip解答してdll探してAddTypeするの面倒くさい

AddType -PackageSource https://api.nuget.org/v3/index.json -PackageName Oracle.ManagedDataAccess -Version 12.2.1100
$connection = New-Object -TypeName Oracle.ManagedDataAccess.Client.OracleConnection

こんなんできたら絶対便利だろ
2018/05/27(日) 01:15:09.38ID:ek08JVnr
そういうコマンドレットを作ればいいんじゃないの
2018/05/27(日) 10:22:45.07ID:FRc1Igvs
こういうのは末端のユーザーじゃなくMicrosoftが責任持って整備すべき仕事だよなぁ
2018/05/27(日) 10:32:40.51ID:uKjxyzN7
>>747
Visual Studioだと全部やってくれるのにな
2018/05/27(日) 10:54:12.69ID:kiqwqKPT
https://www.powershellgallery.com/items?q=nuget&;x=0&y=0
この中にお望みの物ないの?
俺は調べてないけど
2018/05/28(月) 20:48:57.60ID:ANh8mcyB
csv読み込みのときに、♯が入ってる行が消えるのですが回避方法あるでしょうか?
バージョンは2のため、cat|convertfrom- csv を使っています。
2018/05/29(火) 10:01:43.76ID:JWI1PS/k
cat|♯を消す処理|convertfrom- csv
2018/05/29(火) 13:59:12.26ID:/wWb7+KW
半角井桁でも全角井桁でもなくシャープがダメ文字ってことなら、いわゆる機種依存文字に対して内部的に文字化けしてるのかね
Get-Contentの-Encodingパラメーターを変えて試行錯誤してみるのはどうだろ
2018/05/29(火) 20:04:16.63ID:uVfBdj0+
>>753
おっしゃる通りcat時点ではシャープのある行も問題なく表示されていたのでそこでシャープを適当な文字列に置換する事で回避出来ました。
なお文字化け等では無かったためencodingは関係ありませんでしたが、お二方ともアドバイスしていただきありがとうございました。
2018/05/29(火) 21:24:14.97ID:NIS7bYGB
csvでシャープで始まる行はコメントとみなされる
2018/05/29(火) 21:48:09.49ID:JDVJC7kx
C#をAddTypeする#だけに
2018/05/29(火) 22:37:29.79ID:DjF05HP4
>>756
そんな仕様初めて聞いた
Excelは#で始まる行も読み込むよ
2018/05/29(火) 23:17:16.03ID:uVfBdj0+
>>756
そういう仕様なんだね。
プログラム内じゃないんだから勝手にコメントアウトしないで欲しい
2018/05/30(水) 01:59:47.06ID:yjZg0US2
RFCではCSVのコメントなんて定義されてないんだがな
#がコメントとか方言です
2018/05/30(水) 07:47:42.04ID:fRdW4Y4e
「♯を含む行」が消えるって言ってるんだから、実は「#で始まる行」が消えてた、なんてことは流石にないでしょう
2018/05/30(水) 08:14:02.91ID:fRdW4Y4e
と思って検証したらマジじゃねーかバーロー
v2では使えないけどcat -raw|convertfrom-csvなら無視されなくなるから、#がCSVコメントとして無視されてるのではなくて、#をコメント行相当のオブジェクトとして返しているGet-Content側がタチ悪いという話じゃないだろうか
2018/05/30(水) 10:30:58.30ID:962OkqnQ
" で囲んだら大丈夫とか?
2018/05/30(水) 22:12:34.15ID:8qi2Khqy
PCに入ってるPowerShellのバージョンを簡単に切り替える方法はないのでしょうか?
作成したスクリプトがバージョン2でも3でも動くか等の検証を行いたいのですが?
2018/05/30(水) 22:36:17.40ID:JXGp/YkD
旧バージョン互換で動かすオプションあった気がする
766デフォルトの名無しさん
垢版 |
2018/05/31(木) 17:20:46.88ID:ZTEAvdsG
そのCSV は各列を、" " で囲んでないのか?
2018/05/31(木) 21:31:21.76ID:3wC9yI4G
Windows PowerShell 2.0 エンジンの開始
https://docs.microsoft.com/ja-jp/powershell/scripting/setup/starting-the-windows-powershell-2.0-engine
2018/06/01(金) 19:12:06.06ID:j/MM0qyt
ISEがインテリセンス使ったら落ちてたのが
KB4100403で修正されたらしい(未確認)
2018/06/04(月) 18:18:51.32ID:duSCMV5/
エクセルに書き込む時、例えば
for(i=1; -le 1000;i++){
sheet.cells.item(i,1)=i*5

こんな感じにすると非常に動作が遅いのですがもっと高速にする方法はあるでしょうか。
なおvbaでは、
for i=1 to 1000
arr(i,1)=i*5
next
と配列に入れておいてから、
oSheet.Range(oSheet.Cells(1, 1), oSheet.Cells(UBound(arr, 1), UBound(arr, 2))) = arr
と一括で書き込むと速いのですが、PSでもこのような書き方はあるでしょうか。
2018/06/04(月) 19:50:56.49ID:gQR1ea5z
>>769
速いかは知らんけどそれと同じようにするならこんな感じかね

$n = 1000
$arr = New-Object "object[,]" $n,1
1..$n | foreach { $arr[($_-1),0] = [int]$_*5 }
$sheet.Range($sheet.Cells.Item(1, 1), $sheet.Cells.Item($n, 1)) = $arr
2018/06/04(月) 23:24:00.90ID:OF0qTMZ9
>>770
ありがとうございます。多次元配列を使えばよいのですね。
webで調べると多次元配列と多段階配列(ジャグ配列)がごっちゃになってるサイトもあって混乱していましたが、770さんの簡潔な記述をみて理解出来ました。
2018/06/06(水) 23:07:10.85ID:N8yiaTQz
gradle的なタスクランナーDSLは無いの?
2018/06/09(土) 16:51:36.72ID:XSSJlv/Q
PowershellからExcelのユーザフォーム(コマンドボタン)を非表示かクリックできないようにしたいのですが、いくつか試してもうまく設定できませんでした。

ご存知の方がいたら、ご教示いただければ。
2018/06/09(土) 17:03:33.87ID:Tjb3C0On
試したコードを晒せば修正してあげるよ^^
2018/06/09(土) 18:02:05.59ID:54mp5fzV
>>773
別のインスタンスからフォームを操作するってこと?
参考にVBAだとどうやるの?
776773
垢版 |
2018/06/11(月) 12:16:46.97ID:vpJG/a5Y
以下で動くことは確認しましたが、できたらPowershellだけで完結したいです。

$excel = New-Object -ComObject Excel.Application;
$book = $excel.Workbooks.Open('〜ファイル名〜');
$num1 = $excel.Worksheets.count ;
$array = @() ;
for ( $i1 = 1 ; $i1 -le $num1 ; $i1++ ){ ;
if ( $excel.Worksheets.Item($i1).name.substring( 0, 4 ) -eq 'xxx_' ) { ;
$array += $excel.Worksheets.Item($i1).name ;
} ;
} ;
for( $i2=0; $i2 -lt $array.count; $i2++){ ;
$shtname = $array[$array.count-$i2-1] ;
$MDB_index = $excel.Worksheets.Item('MDB').index ;
$excel.Worksheets.Item($shtname).move( $excel.Worksheets.Item( $MDB_index ) ) ;
$excel.Worksheets.Item('MDB').move( $excel.Worksheets.Item( $shtname ) ) ;
$excel.Worksheets.Item($shtname).name = 'yy_' + $shtname.substring( 4, $shtname.length - 4 ) ;
} ;
$excel.run("Unable")
777773
垢版 |
2018/06/11(月) 12:17:21.17ID:vpJG/a5Y
* VBAのUnableの中身 ;
Sub Unable()
Dim SHTNAME As String
Dim NUMBER As Integer
Dim I1 As Integer

NUMBER = ThisWorkbook.Worksheets.Count
For I1 = 1 To NUMBER
SHTNAME = ThisWorkbook.Worksheets(I1).Name
If Mid(SHTNAME, 1, 3) = "yy_" Then
ThisWorkbook.Worksheets(I1).CBT1.Enabled = False
End If
Next
End Sub
2018/06/11(月) 23:51:03.62ID:gcU8d3qp
>>776
xxx_のシートをMDBの後ろに並べたいってことでいいんかね?

$book.Sheets[$book.Sheets.Count..1] | where { $_.name -like "xxx_*" } | foreach {
$_.move([Reflection.Missing]::Value, $book.Sheets("MDB"))
$_.name = $_.name -replace "^xxx_","yy_"
$_.OLEObjects("CBT1").Enabled = $false
}
779773
垢版 |
2018/06/12(火) 12:30:53.64ID:ekyc4Iri
>>778
VBAに依存せず実行できました。感謝。
2018/06/21(木) 19:07:26.37ID:K/kbKit1
windows10ですが
Get-ItemPropertyでLastWriteTimeを見てみると
エクスプローラで表示される更新日時と異なるファイルが有りました

更新日時の方が作成日時より前の日付になってるので
おそらく LastWriteTimeの方が正しい日付だと思います

これを訂正するためにPSからエクスプローラの更新日付を取得したいのですが
エクスプローラの更新日時がどこから来ているものかさっぱりわかりません
2018/06/21(木) 19:25:07.20ID:UNnnYLs6
Utc?
782780
垢版 |
2018/06/21(木) 20:21:17.18ID:K/kbKit1
いくつかファイルを調べてみると、更新日時とLastWriteTimeの差が一週間離れているのも有るので
タイムゾーンの問題とは考えにくいです
よく見ると、作成日時もCreationTimeと10日くらいのずれが有りましたw

エクスプローラが詳細プロパティ以外の日付を参照してる意味が分かりません
windowsの強制メジャーアップデートで何度かクラッシュした影響でファイルが壊れてるのかも
2018/06/23(土) 00:44:45.99ID:Ut6U9K8s
代替データストリームじゃね?
784デフォルトの名無しさん
垢版 |
2018/07/04(水) 22:21:13.01ID:gFgZc5FG
JBF
2018/07/04(水) 23:23:31.98ID:acN7B5+I
なんでこんなに過疎ってるんですか
2018/07/05(木) 22:43:24.58ID:KzEq2oHL
「書き込みがあったら反応しよう」と思ってる人がたくさんいるからかな?
2018/07/08(日) 03:18:34.99ID:3ZrH1Hyw
わしはね、ローカルの小物guiでps始めよう思ってたらhtaというものを発見してしまったんじゃ
2018/07/08(日) 04:04:12.13ID:UfjkVwX1
失われた古代技術
2018/07/14(土) 21:56:02.39ID:RVDUVOmY
若者が「HTAって使えるんじゃね?」と思ってしまうのは仕方がない。
オッサン〜ジジイが「HTAを発見した」つったら「今まで何して生きてきたの?」としか言いようがない。

Windowsでのローカルの小物GUIは、今、滅亡の危機ですらある。
WordやExcelを使った自動化すら、今後もできるかどうか怪しい。
2018/07/14(土) 22:29:26.95ID:LxoRiW+E
HTA軽くていいよね機能追加も楽だし
ランチャーにしてる
2018/07/14(土) 22:38:50.55ID:utl6Xayz
ローカルの小物GUIってなんだよ
2018/07/14(土) 22:50:10.64ID:P6K2NPR4
GUI付のしょうもないアプリ
2018/07/14(土) 23:12:51.46ID:RVDUVOmY
ローカル実行できるスクリプトで動くGUIアプリに決まってるだろ。
Excel や Access の VBA がその代表格。
COM がベースだから切られる方向なのは分かる。
でも代替できるものがない。

いっとき PowerShell+WPF が期待を担ったが…
・呼ばれる側のアプリにコマンドレットの実装が必要
・.NET ごとオープンソースの世界に行ってしまって Windows そのものが切られそう
・そういうのは C# で書いて配れ、と明示的に言ってくれた方がまだ楽。

が、MS はダンマリを決め込んでいるんだよなぁ…
2018/07/15(日) 00:32:04.05ID:X2092vNg
>>791
なんなんでしょうね
2018/07/15(日) 01:35:23.34ID:0pMWk4zA
>>793
>COM がベースだから切られる方向なのは分かる。
>でも代替できるものがない。

よく調べてないんだけどVisual Studio Tools for Officeとかはダメ?
2018/07/15(日) 01:35:37.01ID:SEkGxxwq
powershell入ってないXP以下で使えるんすよ
判ってくださいよ
2018/07/16(月) 21:11:22.99ID:HqjsUdw9
とりあえず、PowerShellが「最強CUI」とかいう寝言は取り下げた方がいい。誤解を招く。
2018/07/16(月) 21:19:57.77ID:Qq5myI16
はいはい、しゅごいでちゅねー
2018/07/16(月) 21:42:32.84ID:h7LXYR/p
最強だが。
ただ使っている人は少ない。
2018/07/16(月) 21:51:20.37ID:XBIjWYki
>>797
誤解してるのはお前だけだからお前がどっかに行けば解決
2018/07/17(火) 23:10:59.27ID:yoTx9oxy
>>798-800
管理目的なら最強だろう。確かに。
が、それ以外の目的にはおおよそ優しくない。てゆーか元の開発陣がそう言ってる(管理目的、API指向)。
OSSになったから 6以降も(3でもやったけど…)破壊的な仕様変更をゴリゴリやりそう。

特に PowerShell Desktop は今後バージョンアップは無さげだから、管理系以外の Win系のユーザーは手を出す理由がない。
Win系ですら 「引き継ぎを考えたら VBScript で書いておこうか…」てなる。
WPF は死亡寸前だし。

Winユーザーはバッチや VBScript の後継としての役目を捨てようとしている PowerShell に文句を言う筋合いはあると思うがね。
純粋な対話型CUI の最強は bash系列だし。

何言ってんの??
どこがどう最強なのか言って欲しいわ。

特に、Office系の自動化なんて COMオブジェクトに頼らないと無理だろ。
PowerShell で書くといちいち Excel のセルですらリソース開放が必要でクソ面倒。
Set objExcel = Nothing
とサクッと書けるほうがいいに決まっている。

PowerShell は万能じゃねーんだよ!馬鹿ども。
2018/07/17(火) 23:14:01.71ID:fhQFSH5P
>>801
管理目的とは?
2018/07/17(火) 23:20:39.18ID:fwrxWQ2y
C#erだから.NETライブラリがそのまま使えるPowerShell好きだわ
2018/07/17(火) 23:25:15.93ID:fhQFSH5P
>>803
どんな用途で使ってる?
2018/07/17(火) 23:32:27.62ID:fwrxWQ2y
>>804
最近作ったのはCのヘッダーからC#ラッパー生成するやつ
2018/07/18(水) 12:45:25.76ID:xS6rtIKl
vbsからpsをキックする
2018/07/19(木) 23:44:42.87ID:puBIzWD6
>>806
生理的に嫌すぎる
2018/07/22(日) 13:00:02.17ID:ZN+SAgqe
VBAスレに来てるPowerShellゴミクズ荒し何なの?

PowerShellの工夫はより良くするための工夫でVBAの工夫は欠陥を補う工夫って、どのロで言うんだろうね。
VBAだとソース管理出来ないというから、ソース抜き出してソース管理ツールに渡すのはダメという意味なんだろうけど、その割にPowerShellだとVisualStudioと連携できるとか言い出すダブスタ。

PowerShellでC#コンパイル出来るとか、バカ丸出し。
csc使うんだったら何だって出来るだろう。
コイツがムカつくのはそういう工夫を全て否定する所。
それを否定するならPowerShellだってゴミクズだろう。

そういう工夫こそが大事なのに。
2018/07/22(日) 13:30:20.53ID:FoHjHQaV
スクリプトなんて適材適所で何使ったっていい
他人がなんかいちゃもん付けてきたら、
「こいつ初心者で一時的に心酔してバカ発言してるんだな、
 あと数ヶ月もすればこのときのことを思い出して恥ずかしさにそこらへんを転げまわるんだろうな」
程度に気の毒がってりゃいいさ
2018/07/22(日) 13:32:06.23ID:G9t5vsVs
エクセルなんて要らん工夫して紙と電卓を使いこなせば事務作業はできる

会社に支給されたパソコンを目の前置いて、こう主張するおじいさんが居たらどう思う?
馬鹿だねーエクセルなんて簡単なのになんで電卓使うの?
社員ならエクセル使っていいのになんで?
そう思わないかな?

もし思わないなら根本的に感覚がズレてるので同意を得るのは難しいと思うよ
2018/07/22(日) 13:33:43.75ID:/fuF+goF
つかわざわざこっちにきて何がしたいん?
そいつに言えばいいやん
お前もゴミだろう
2018/07/22(日) 13:35:02.58ID:G9t5vsVs
>>811
ことごとく論破されたので逃げてきたんだろう
813デフォルトの名無しさん
垢版 |
2018/07/22(日) 14:06:13.49ID:YGqHpPTt
>>811
VBAのスレが荒れるのが嫌だからでしょ
考えたらわかるじゃんw 脳みそあるの?
814デフォルトの名無しさん
垢版 |
2018/07/22(日) 14:07:05.72ID:YGqHpPTt
>>812
PowerShellユーザが迷惑かけてるんだから
スレとしての責任が問われてる
2018/07/22(日) 14:07:45.01ID:ZN+SAgqe
散々論破しているのに最後まで居座られて迷惑してスレが終わったからだよ。
そしてPowerShellの立場はExcelと被るわけでどっちも適材適所だろ。
その場に合ったのを使えば良いんだ。

奴は自分がPowerShellを貶めてるのに気付いて無い。
2018/07/22(日) 14:15:13.20ID:/fuF+goF
責任とって立ててきてやったぞ
存分にレスバを楽しんでくれ

Excel VBA 質問スレ Part55
https://mevius.5ch.net/test/read.cgi/tech/1532236398/
2018/07/22(日) 14:16:06.18ID:WPYgWuMH
読んできた
Rubyキチが紛れてるのが無理矢理すぎて笑える
818デフォルトの名無しさん
垢版 |
2018/07/22(日) 14:17:54.05ID:YGqHpPTt
>>816
馬鹿野郎、てめんとこの人間が迷惑かけてんだから
うちの者がご迷惑おかけして申し訳ありません
と謝罪するのが筋だろうが
819デフォルトの名無しさん
垢版 |
2018/07/22(日) 14:19:08.41ID:YGqHpPTt
ほんとPowerShellは他人に迷惑かけてバッカやな
ほんまクズやな、PowerShellのせいやろな
2018/07/22(日) 14:20:41.76ID:/fuF+goF
照れんなよ
立ててくれてうれしいんだろ
821デフォルトの名無しさん
垢版 |
2018/07/22(日) 14:23:23.96ID:YGqHpPTt
行動は早いけど間違ってる人っているよね
2018/07/22(日) 14:24:51.70ID:1tw3f2DK
オマエやんそれ
レスは早いがトンチンカン
823デフォルトの名無しさん
垢版 |
2018/07/22(日) 14:26:02.34ID:YGqHpPTt
>>822
ぼくは何も行動してないからね、完全に無害だけど
スレ立てしちゃった人がいるんだよ、ぼくはその人を知ってるんだ
824デフォルトの名無しさん
垢版 |
2018/07/22(日) 14:26:31.77ID:YGqHpPTt
>>816
こいつです、こいつVBAのスレを立てやがりました
2018/07/22(日) 14:27:18.37ID:/fuF+goF
褒めすぎんなよ
当然のことをしたまでよ
826デフォルトの名無しさん
垢版 |
2018/07/22(日) 14:27:57.35ID:YGqHpPTt
自分がどれだけ悪いことをしたのかについてもわかってないと思います
頭の悪い人っているんだなって思いました
827デフォルトの名無しさん
垢版 |
2018/07/22(日) 14:28:40.17ID:YGqHpPTt
https://pbs.twimg.com/media/CkhWReGUgAAJvHw.jpg
828デフォルトの名無しさん
垢版 |
2018/07/22(日) 14:30:32.96ID:YGqHpPTt
自発的に間違った行動をとる組織にとってのガン細胞が確認されました
829デフォルトの名無しさん
垢版 |
2018/07/22(日) 14:30:55.52ID:YGqHpPTt
>>816 こいつガンです
830デフォルトの名無しさん
垢版 |
2018/07/22(日) 14:31:21.33ID:YGqHpPTt
ガン、お前だったのか!?
831デフォルトの名無しさん
垢版 |
2018/07/22(日) 14:31:43.01ID:YGqHpPTt
大造じいさんとガン
832デフォルトの名無しさん
垢版 |
2018/07/22(日) 14:33:56.27ID:YGqHpPTt
なんでVBAのスレ立ててもうたんや
何してくれてんのや
PowerShellユーザが言い訳できないレベルで
全面的に悪いことになってまうやろ
833デフォルトの名無しさん
垢版 |
2018/07/22(日) 14:35:11.72ID:YGqHpPTt
なんでや!?なんでやねん!なんでスレ立ててもうたんや!!
なんでもっと冷静に行動でけへんねん
スレ立てたら済むと思ったんか?
なに考えてんねん
834デフォルトの名無しさん
垢版 |
2018/07/22(日) 14:36:13.45ID:YGqHpPTt
なんでこんな前例を作ってしまったんや
この過ちはPowerShellの後世に禍根を残すで
835デフォルトの名無しさん
垢版 |
2018/07/22(日) 14:37:09.12ID:YGqHpPTt
>>831
大造じいさん「ぐぅぅ、わしはもうだめや・・・」
■ このスレッドは過去ログ倉庫に格納されています
5ちゃんねるの広告が気に入らない場合は、こちらをクリックしてください。

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