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

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

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

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

Q&A

解決済

1回答

1375閲覧

営業日の前日日付を出したい

yamato_0410

総合スコア36

PowerShell

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

1グッド

0クリップ

投稿2018/09/06 02:15

編集2018/09/06 02:18

Powersellで営業日の前日日付を出したいのですがうまくいきません。

ps1の中身****

#基本情報の設定
$NEXTDATE = (Get-Date).AddDays(-1)
$HOLIDAYFILE = Get-Content C:\Users\Desktop\holidaylist.txt #祝日(厳密には会社の土日以外の定休日)をリスト化したファイル
$HOLIDATE = ($NEXTDATE).ToString("yyyyMMdd")
$WEEKDATE = ($NEXTDATE).DayOfWeek

do {
do {
#土日判定
if ( $WEEKDATE -eq "Saturday" ) {
$NEXTDATE = $NEXTDATE.AddDays(-1)
$HOLIDATE = ($NEXTDATE).ToString("yyyyMMdd")
$WEEKDATE = ($NEXTDATE).DayOfWeek
} elseif ( $WEEKDATE -eq "Sunday" ) {
$NEXTDATE = $NEXTDATE.AddDays(-2)

$HOLIDATE = ($NEXTDATE).ToString("yyyyMMdd") $WEEKDATE = ($NEXTDATE).DayOfWeek } #祝日判定 $HOLIDAYFILE | ` foreach -Process { if ( $HOLIDATE -eq ( $_ )) { $NEXTDATE = $NEXTDATE.AddDays(-1) $HOLIDATE = ($NEXTDATE).ToString("yyyyMMdd") $WEEKDATE = ($NEXTDATE).DayOfWeek } } ` } while ( $WEEKDATE -eq "Sunday")

} while ( $WEEKDATE -eq "Saturday")

echo $NEXTDATE.ToString("yyyyMMdd")


holidaylist.txtに
20180903
20180904
20180905

と記載しても
結果が20180904として出てしまいます。
何が問題でしょうか?

宜しくお願い致します。

legitwhiz👍を押しています

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

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

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

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

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

guest

回答1

0

自己解決

すみません、テキストを降順にしたらいけました。

投稿2018/09/06 02:24

yamato_0410

総合スコア36

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問