IT仕事

CliborとPythonで明日(昨日)の日付を出す

投稿日:

Clibor、使ってますか? 私は毎日使っています

例えば、「2018/07/02(月)」のように明日の日付を書きたいと思ったら、どうやって入力していますか?
キーボードで13個以上のキーを押して、曜日の部分に差し掛かったら、英数モードを日本語入力モードに切り替えて、タイプしますか?
私はうん十年間、そのようにしてきたのですが、さすがに嫌になってきました。

それでも最近は知恵をつけてきて、Windows10のIMEなら、「明日(あした)」と入力して変換します。
すると下のほうに「2018年7月3日」「7月3日(火)」などが変換候補に挙がってくるので、その中から選びます。
このやり方なら、打つキーの数が1/4位になります。

ならばそれ使えばいいじゃん、ということではあるのですが、なぜかその候補に、私の欲しい「2018/07/02(月)」のフォーマットが無いのですよ。

ということで、CliborとPythonで、何とかします。

# -*- coding: utf-8 -*-
#<$C_CLB_PYTHON/>
import win32api,win32com.client,win32clipboard as CB,datetime
import datetime as dt
#
win32api.Sleep(100)
shell = win32com.client.Dispatch("WScript.Shell")
#
now = dt.datetime.now() 
r = now + dt.timedelta(days=1) 
tnstr = r.strftime('%Y/%m/%d')
yobi = ["月","火","水","木","金","土","日"]
text = tnstr + '(' + yobi[r.weekday()] + ')'
#
win32api.Sleep(100)
CB.OpenClipboard()
CB.EmptyClipboard()
CB.SetClipboardText( text, CB.CF_UNICODETEXT )
shell.SendKeys("^v")
CB.CloseClipboard()
#

上記のコードをCliborの定型文に入れて、Ctrlキー2回+右カーソルキー1回+数字キー1回の、計4つのキーのみで、明日の日付を入れられるようになりました。
ちなみに「r = now + dt.timedelta(days=1)」の最後を「-1」にすると、昨日の日付を出せます。

これでまた少し、自分好みの使いやすさに!

Pythonの日付処理は、以下の記事を参考にしました。
datetimeで曜日を調べる

-IT仕事

執筆者:

関連記事

Excel2013 セル入力直後から確定までが遅い

オプション-詳細設定-表示の、「ハードウェア グラフィック アクセラレータを無効にする」のチェックで、すごく改善した。 自分の周りで相当悩んでいる人がいたので、一緒に調べた結果、わかった。 他にも悩ん …

no image

VBAでプリンタ切り替え

xlSheet.PrintOut(ActivePrinter:=”ココにプリンタ名”) でVBAの中でプリンタを切り替えできるんだなあ。 こんなコマンドもあるのか。 知らなかっ …

no image

Excelで作ったVBAマクロのシートをZohoで使えるか試してみた

結論でいうと、うごくは動くが、完全ではない。 で、その不完全さが、致命傷だったりする。 自分の場合に気がついたこととして、 ■よいところ ・Googleのアカウントでログインできる。 ・わかりやすい。 …

no image

B2の送り状の印刷時に、どうしても3枚(無駄紙2枚)出てしまう。

クロネコヤマトのB2送り状ソフトを使っているのだが、標記の件で毎日いらいら。 今回、色々やって解決に至ったのでメモ。 やったこと: プリンタドライバの設定画面で、用紙サイズを変更したり、フィットページ …

no image

教育訓練給付制度

おや? 久々にITCの公式HPを見ると、こんな記述が。 「ITコーディネータ補資格認定用ケース研修は、2005年度より、厚生労働省教育訓練給付制度の対象講座になっておりません」 私が受験した2年前は、 …