質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
PowerShell

Windows PowerShellはコマンドラインインターフェースであり、システム管理を含むWindowsタスク自動化のためのスクリプト言語です。

Q&A

解決済

2回答

973閲覧

日付での実行判定の方法について

jackal1978

総合スコア33

PowerShell

Windows PowerShellはコマンドラインインターフェースであり、システム管理を含むWindowsタスク自動化のためのスクリプト言語です。

0グッド

0クリップ

投稿2022/07/29 02:35

編集2022/07/29 05:45

前提

実行したスクリプトの日付が「.txt」で吐き出されます。
テキストの吐き出し先は1つのフォルダ内になります。
例)
C:¥hoge
20220722.txt
20220715.txt
20220618.txt
20220602.txt
20220521.txt

実現したいこと

ユーザに対して制限解除のスクリプトを実行可能にしたいと考えております。
しかし何度も実行可能にするのも不都合があるため一月に2回までと制限をかけ、3回目に実行しようとすると
メッセージが表示され実行できないようにする仕掛けをスクリプトで実現したいと考えております。
スクリプトを実行した際に前提のテキストを吐き出し判定を行い実行の有無を分岐させたい。
上記前提だと「202207」から始まるテキストは既に2つあるので3回目を実行しようとしたときに「実行できない」メッセージを表示させたい。

発生している問題・エラーメッセージ

エラーメッセージ

該当のソースコード

$path = "C:\hoge" $file = (Get-ChildItem $path\*.txt).BaseName ←.txtの拡張子を外します $file.SubString(0,6) ←文字列で「yyyyMM」の年月だけ取り出します $y = Get-Date -Format "yyyyMM" $fileにはyyyyMMのリストが格納されています。 $yには同じくyyyyMMが格納されていて、文字列が同じものを抽出しカウントしたいと考えています。 2個までであれば処理を実行。3個以上はエラーにするスクリプトをご教示ください。

試したこと

当方Powershellが初心者なのでどういうことが可能かがよくわかっておりません。

補足情報(FW/ツールのバージョンなど)

https://qiita.com/kurosworld/items/35060a3e695df9feaa0a

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Zuishin

2022/07/29 04:42

> 考え方含めてご教示いただけると助かります。 目的が果たせるよう好きにすればいいと思います。 ネックになりそうなのはユーザーの権限と改竄でしょう。
jackal1978

2022/07/29 04:50 編集

>Zuishinさん 追記ありがとうございます。 当方で不明な部分はフォルダ内に格納されているテキストを読み込んで同じものが3つ以上(※1)になったときに エラー判定ができるようなスクリプトの作成が可能かどうかになります。 ※1:テキストで年/月の値
Zuishin

2022/07/29 05:10 編集

それで目的が果たせるようには思えませんが、ユーザー毎のテキストファイルに年月(たとえば 202207)を追記していき、その最後から 3 行目を取り出して、それを現在日時と比較すれば良いんですよね? 2 行までしかなければ true で、それ以上ある場合は Select-Object などで後ろから 3 行目を取り出し、比較すれば良いと思います。 次のコマンドをコマンドラインから実行し、結果を見てみてください。 (Get-Date).ToString("yyyyMM") (1, 2, 3, 4, 5, 6, 7)[-3]
jackal1978

2022/07/29 05:33 編集

>Zuishinさん 追記ありがとうございます。 例えば 前提条件のテキストが格納されています。 $path = "C:\hoge" $file = (Get-ChildItem $path\*.txt).BaseName ←.txtの拡張子を外します。 $file.SubString(0,6) ←文字列で「yyyyMM」の年月だけ取り出します。 $y = Get-Date -Format "yyyyMM" ←スクリプト実行日を取得します。 3行目と4行目でなんらかの比較を行い判定することはできないでしょうか? 例えば一致したものをとりだして、その個数が3個以上だとエラーになるようなスクリプトとかむずかしいでしょうか?
Zuishin

2022/07/29 05:35

質問を見直して、回答できるだけの材料を「全て」書くのが良いと思います。
guest

回答2

0

2個までであれば処理を実行。3個以上はエラーにするスクリプトをご教示ください。

2個で処理を実行すると3回目実行してしまいますよね?実行するのは0か1個のときではないでしょうか?


要求:
1月に2回までしか実行できないようにしたい、2回実行済みなら実行できない旨メッセージを出力

要件:
(実行回数はyyyymmdd.txtの同月のyyyymmの数から判断できる。)
実行回数を取得する。回数が1以下(0or1)なら実行、それ以外(想定では2)は実行できない旨メッセージを出力して終了

設計:
実行回数の取得

  1. 条件(実行日のyyyymm)に合致するファイル一覧を取得
  2. 1)の行数を取得することでファイル数を取得

回数による判定
3) if構文で 2)が1以下なら実行、それ以外は実行不可の旨メッセージ出力

PowerShell

1$path = "C:\hoge" 2$yearMonth = Get-Date -Format "yyyyMM" 3$yearMonth 4$items = Get-ChildItem -Path $path -Include $yearMonth*.txt -File -Name 5$items 6# $items = Get-ChildItem $path $yearMonth*.txt -File -Name でも結果は同じでした 7 8if ( $items.Count -le 1 ) { 9 "処理を実行します" 10 # 本来の処理を実装 11} 12else { 13 "今月は既に2回実行しているため、これ以上は実行できません" 14} 15

PowerShellに関して、ネットで調べたコマンドをプロンプトでコピペで実行する程度の知識しか私にはありません。
質問者さんと同じように「どういうことが可能かがよくわかっていない」状態です。
どんな言語でもすべての機能を把握している人は早々いないのではないかと思います。
知らない機能だが実装したい要件があるとなれば、ベテランでもそれができるかまずは調べるのではないでしょうか。

何がしたいかを単純な処理に落とし込んで、それがPowerShellで実現できないか調べた結果が上記です。
調べたのは以下ぐらいです。
・PowerShellスクリプトの拡張子
・特定条件(202207*.txt)に合致するファイル一覧を取得する方法
・Get-ChildItemの使い方・オプション
・その結果の行数を取得する方法
(始め.Lengthを使ったが、テストの際ファイル1つの場合うまくいかなかった。再度調べて.Countを採用)
・if文

投稿2022/07/29 16:59

Crimson_Tide

総合スコア509

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

jackal1978

2022/07/30 00:39

コメントありがとうございます。 yyyyMMを取得までは出来たのですが、複数あったときの一覧の取得方法を調査したのですが見つけられず、If文についてもなんとなくできるかも?程度でした。少しづつ勉強していこうと思います。 この度は凡例をありがとうございました。
guest

0

ベストアンサー

3個以上は「実行できない」メッセージを表示

PowerShell

1$path = "C:\hoge" # 格納場所 2$file = (Get-ChildItem $path\*.txt).BaseName # .txtの拡張子を外します。 3$yyyymm = $file.SubString(0,6) # 年月だけ取り出します。 4$y = Get-Date -Format "yyyyMM" # スクリプト実行日を取得します。 5$Datas = $yyyymm | Group-Object -noelement # すべてのファイル名(yyyyMM)をグループ化します。 6foreach ($Data in $Datas){ # ループ 7 if (($Data.Name -eq $y) -and ($Data.Count -ge 3)){ # yyyyMM同一判定 及び 3個以上を判定します。 8 Add-Type -AssemblyName System.Windows.Forms # アセンブリ 9 [void][System.Windows.Forms.MessageBox]::Show("実行できない","","OK") # 表示 10 } 11}

本プログラムは、すべてのファイル名(yyyyMM)をグループ化しています。
個数の判定は可能になりますが、大量のファイルが存在する場合、
非常に効率が悪くなります。

投稿2022/07/29 13:04

ccc-

総合スコア342

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

jackal1978

2022/07/29 15:01 編集

ありがとうございます。スクリプトに組み込んでうまく動作することを確認いたしました。 >個数の判定は可能になりますが、大量のファイルが存在する場合、 >非常に効率が悪くなります。 上記のご指摘に関しては年に1回タスクスケジューラ等を使って該当のフォルダ内を削除や移動をして最大でも36個程度にするようにする等の工夫を考えてみようと思います。 迅速なご対応いただけて助かりました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問