IT仕事 MS Access

Excelで使える祝日判定のWebAPIを見つけた

投稿日:

Excelの関数には、曜日を判定できる関数(WEEKDAY)が用意されている。また、表示だけなら書式設定でもできる。しかし祝日となると、関数も何も、用意されていない。
祝日は年により、突然増えたり、「来年からは第〇週目に変更」などとなったりするので、対応が難しいのであろう。

それでも何か方法がないかと「excel 祝日」などでGoogle検索すると、Google Calendar API を利用する方法がトップに出てくる。
見つけた時はうれしかったが、よくよくページを見てみると、コードが恐ろしく長く、また随所に使いにくい部分が出てくる。

さらに簡単な方法がないか探して、やっと見つけた、サンプルサイトが、以下。

国民の祝日チェック

上記のサイトでは、祝日判定のWebAPIを提供している。
ブラウザのURLに、http://s-proj.com/utils/checkHoliday.php?kind=h&date=20170503 をコピペしてEnterキーを押すと動きが分かるが、末尾の8桁の数字でもって祝日かそうでないかが、シンプルかつエレガントに分かるようになっている。

その仕組みを使わせていただいて、ExcelVBAに取り込んでみたのが、こちら。Accessでも使える。
実際に使う際は、Debug.Printしている部分を、セルに入れたり、テキストボックスに代入したり、することになろう。

[code]
Sub httpRequest()
‘ 祝日判定
‘ 国民の祝日チェック <http://s-proj.com/utils/holiday.html>

Dim HttpReq As MSXML2.XMLHTTP60
Dim DomDoc As MSXML2.DOMDocument60
Dim targetURL As String

targetURI = "http://s-proj.com/utils/checkHoliday.php?kind=h&date=20170503" ‘20170503部分を任意の数値に

‘HTTP GET
Set HttpReq = CreateObject("MSXML2.XMLHTTP")
HttpReq.Open "GET", targetURI, False
HttpReq.send (Null)

Set DomDoc = CreateObject("MSXML2.DOMDocument.6.0")
DomDoc.LoadXML (HttpReq.responseText)
Debug.Print HttpReq.responseText

Set HttpReq = Nothing
Set DomDoc = Nothing

End Sub
[/code]

いいものが見つかって、うれしい。
作者さん、ありがとうございます。

-IT仕事, MS Access

執筆者:

関連記事

no image

まだやってる、IT講師。

今日はWordでPOPを作るセミナー。 いわゆる「おばちゃん」相手。 楽しい。 なかに、とても入力が苦手な人が一人、「産業会館」という字を、「惨状会館」と入力して、しかしどう直してよいか分からなくて悩 …

no image

空メールを送る仕組みをはじめて作るのに苦労した記録

4日間、苦労。モウイヤ。 ■1日目: 携帯から空メールを送ったら、サーバがクリックしてほしいURLと送り主のメルアドを本文に書いて返す仕組み、それを作りたい。しかし何を準備してどうすればよい? まずは …

no image

Linkstationの新旧入れ替えにまつわるバックアップUSBディスクのトラブル

バッファロー製NASのLinkstationのHD-HG160LANに、USB接続で外付けHDDをくっつけて毎週バックアップを取るという構成で、今まで使ってきた。 しかしこのたび、容量の限界が来たため …

no image

Win7初体験・初トラブル

会社の人が初めてWin7入りPCを買ったので例によってトラブルに遭遇した。 ファイルサーバにアクセスしようとすると、「ネットワークパスワードを入力して下さい」のダイアログが出る。それでつながらない。 …

秀丸で、例えば「123市」を「123都市」にするときの正規表現の使い方メモ

検索文字のうち、置き換え後に残したい部分を、カッコで囲むのがミソ。 検索文字:([0-9])市 置換文字:\1都市 wordだと「ワイルドカードを使用する」とすると、正規表現が使える。 関連投稿: 改 …