テキストファイルを読み込み、置換して、上書き保存するプログラムを作成しています。
テキストファイル内には1行ごとに8桁の同じ日付が2箇所入っており、
その日付が昨日以前なら、1ヶ月プラスし、それ以外ならそのまま置いておくようにしたいです。
※1行ごとに日付がプラスされていきます。
以下のコードを書いておりましたが、書き込みがうまくいきません。
原因と解決策のご教示をお願いいたします。
Python
1import datetime 2from dateutil.relativedelta import relativedelta 3 4#ファイルを1行ずつ読み込み 5with open("copyのコピー2.txt", encoding="utf-8")as f: 6 for line in f: 7 #8桁の数字のみ取り出し、日付に変更(現在日時もnowに代入) 8 txtdate = line[16:24].rstrip("\n") 9 txtdate_after = line[66:74] 10 date = datetime.datetime.strptime(txtdate, "%Y%m%d") 11 today = datetime.datetime.now() 12 yesterday = today - datetime.timedelta(days=1) 13 #取り出した日付が昨日以前だったら、月を+1ヶ月する 14 if date < yesterday: 15 nextmonth = date + relativedelta(months=1) 16 nextmonth_date = nextmonth.strftime("%Y%m%d") 17 txtdate = nextmonth_date 18 txtdate_after = nextmonth_date 19 last = line[0:16] +txtdate+ line[24:66]+txtdate_after + line[74:81] 20 with open("copyのコピー2.txt", "w",encoding="utf-8")as f: 21 f.write(last) 22 else: 23 with open("copyのコピー2.txt", "w",encoding="utf-8")as f: 24 f.write(line)
テキストファイルの中身
if not exist 99\20190301.ddd copy \SVOaaaaa\bb_daaa\OO_OUTPUT\99\20190301.ddd 99
if not exist 99\20190302.ddd copy \SVOaaaaa\bb_daaa\OO_OUTPUT\99\20190302.ddd 99
if not exist 99\20190303.ddd copy \SVOaaaaa\bb_daaa\OO_OUTPUT\99\20190303.ddd 99
・
・
・
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。