スキップしてメイン コンテンツに移動

NDLサーチで蔵書録づくり



家の本棚を整理したく、また某図書室の整理ボランティアも買って出た関係で、本の分類番号を取得したくなった(背ラベルの消えた本多数)。

蔵書録をつくるプログラムは前にも Excel VBA + Amazon API で作ったけど、Amazon APIから日本十進分類法(NDC)の番号はもらえない。まあ当然。

今回は、国立国会図書館のAPIとGoogle Apps Script (Google Spreadsheetにバインドしたプロジェクト) で作ることにした。
仕組みはこんな感じ:
  • UrlFetchApp.fetch で下記URLにqueryの値を追加してリクエスト
    https://iss.ndl.go.jp/api/sru?operation=searchRetrieve&recordPacking=xml&recordSchema=dcndl_simple&onlyBib=true&maximumRecords=20&query=
    
    • query の中身はたとえば
      isbn="1234567890"
      とか
      title="あいう" AND creator="かきく"
      とか。それを encodeURIComponent でエンコードしたもの。
    • NDLへのリクエストは5秒に1回という制限があるので、Utilities.sleep で適宜待つ。
  • fetchした結果を XmlService.parse して内容を取り出す。namespaceの指定が全部必要。無印タグにも必要(はまった)。XMLの常識?もう何もかも忘れてる。
  • 検索結果が1件なら、そのままSpreadsheetに書き出して、次の本を再帰的に検索。
  • 複数あれば ui.showModalDialog でダイアログを表示して選択させる。ダイアログから google.script.run() で書き出す関数を実行。successHandlerで次の検索を再帰的に呼び出し。
  • ダイアログはいつ閉じれば?と迷ったけど、単純に上の実行の次行に google.host.close() でできた。
  • 検索キーはisbnまたはtitle。titleが短いばあいは完全一致指定 (title exact "あいう")。
    • 一般的なタイトルの場合、違う本がたくさん見つかってしまうので、creator、publisher 指定で再検索できるようにした。

困ったこと、気づいたことなど:
  • 複数図書館の蔵書から一括で検索してくれるので、ほとんどの本が見つかるのはありがたい。
  • 半面、ほとんどいつも複数件の結果からダイアログで選ぶことになるので、自動化という意味ではあまり…
  • でも検索結果から機械的にどれかを選ぶのは難しい。図書館によってデータ内容けっこうまちまちだから。
  • でも家の本はともかく、図書室の冊数だとつらい。割り切りモードを作ろうか。NDC8を含む1件を自動採用する。

コメント

このブログの人気の投稿

GAS 同一カラムを複数条件でfilterできない件

Google Apps Script でSpreadsheetをデータベース代わりにwebアプリをポチポチ作ってて、スクリプトからSpreadsheetにフィルタかける場合、同一カラムに複数条件を設定できないことを知って残念……。 フィルタのかけ方はこんな感じ。 日付を範囲指定したいけど、After、Before片方しかつけられない。 var dataFile = SpreadsheetApp.openById(DATA_FILE_ID); var sh = dataFile.getSheetByName(LOG_SHEET_NAME); var criteriaDateAfter = SpreadsheetApp.newFilterCriteria().whenDateAfter(new Date(targetDate)).build(); var criteriaUserEqual = SpreadsheetApp.newFilterCriteria().whenTextEqualTo(user.id).build(); if (sh.getFilter()) { sh.getFilter().remove(); } var r = sh.getRange(1, 1, sh.getLastRow(), sh.getLastColumn()) .createFilter() .setColumnFilterCriteria(DATE_COL, criteriaDateAfter) .setColumnFilterCriteria(USER_ID_COL, criteriaUserEqual) .getRange(); FilterCriteriaに2回条件設定してみたり var criteriaDateRange = SpreadsheetApp.newFilterCriteria() .whenDateAfter(new Date(date1)) .whenDateBefore(new Date(date2)).build(); 同じカラムに2回条件設定してみたり var r = sh.getRange(1, 1, sh.get

兵士というもの

体制への信頼、懐疑、雰囲気といった変化していく現象を、あとから測定するためのひとつの方法が、行動を突き止めるというやり方である。 国立銀行への貯蓄高、死亡広告の文面、アドルフと命名された子どもの数、教会脱退者などなど。民族同胞の雰囲気が頂点に達したのは1937年から1939年の間、1941年以降は急速に低下した。 政治的に始まった抑圧を日常的実践へと移しかえたのは、人々が受動的であり、抑圧を容認し、批判的な言動を同じ考えの持ち主の間でしか行わなかったからであった。p.55 これこそが、近代的人間が一見暴力とは無縁であるかのように見える原因なのだ。人々は暴力を想定しておらず、暴力が起きたならば、それはなぜなのかつねに説明を探し求める。たとえ、何らかの手段としての暴力ではなかったとしてもである。それにたいして、自らの身体的不可侵性が保障されていると信じていない者は、常に暴力を想定し、それが起きても動揺することはない。したがって信頼と暴力のバランスはつねに微妙で難しいものとなる。p.77 暴力というものが反文明的なものであり、抑圧されなければならず、深刻な場合には撲滅しなければならないものという形を取るようになったのは、歴史的に見ればようやく近代になってからのことである。暴力それ自体が非難されるべきこととされ、もちろん手段としての暴力は避けられないとしてもその都度正当化が必要とされるか、もし起こってしまったとすれば説明が必要なものとなった。p.78 しかしたとえば、人間が性欲を持つということに理由づけは必要だろうか。食べたり飲んだり息をしたりすることに[中略]したがって説明が求められるのはその様態であって、根本的な動機ではないのだ。おそらく暴力の場合にも、そのように考えることが有益であろう。[中略]結局のところ人類が生き延びたのは、平和を作り出す能力ゆえではなく、狩猟のさいや、食料を争うあらゆる種類のライバルにたいして行使した暴力ゆえなのである。p.78 家庭という領域では依然としてパートナーや子供、ペットに対する暴力が存在しているし、教会や学生寮といった閉鎖された社会領域でも同様である。[中略]おそらく、日常生活から暴力が無縁になるにつれ、象徴的もしくは代理的に行使される暴力への欲求が高まるのだろう。そして国家間でも依然として、暴力は独占からはほど遠い。p.79

佐藤忠良・安野光雅『ねがいは「普通」』

創作の目標のひとつにしたい佐藤忠良さんの対談。 絵をまた描きはじめた目で読むと、あちこち響いてくる。 満州に行かされていたんです。じきにソ連が参戦し、突撃ってことになって――。僕は戦線から逃げ出したんですよ。隊長を誘惑してね。その時、逃げるっていっても行く先がはっきりしないんですよ。日本海を泳いで帰るわけにもいかない。あのころ三十三歳くらいでしたか、元気だったんですね。先が見えないなら、地続きの、かねて憧れていたパリまで、歩いて行くより仕方がない――真剣に考えたんです。 人の顔をつくるとき、その人の怒りや喜びや過ごしてきた時間――粘土の中にね、過去と現在と未来までも、かっこいい言い方すると時間性をぶち込もうとするんです。それが彫刻家の苦しさだと思う。[中略]永く鑑賞に耐える芸術は、時間性を持たなくては――。  彫刻って、手でいちばん苦労するんです。手の動き方一つで、きざになったり、甘ったれたものになってしまったり。手の位置にも苦労しますね。 たとえばリンゴを描きたいというときは、その作家の全内容が投影して、書きたくなるわけです。描きたいなって思ったときに、作者のあらゆる哲学的なものや、思想的なものが投影できれば、絵のリンゴのほうが実際のリンゴよりよく見えてくる――。 でも、シベリアに抑留されていた三年間、男ばかりで過ごしていると、本当に、すべてのことを見せ合ってしまう。その時、我々日本人っていうのは、教養と肉体がバラバラになっていると思いました。 僕は日本にいるときから、ヤギなんかずいぶん描いていて、シベリアにいたときは描く紙がないから、心に絵を描くみたいにしてヤギを見ていたんです。 いや、目の前にして言うのはなんですが、何度見ても飽きないものをつくるのは難しいことです。特に気品あるものを作るというのは――。(安野) 僕はいつも思うんですよ。隣人への憐れみがない芸術は嘘ですよ。<中略>気品のないもの、隣人へのいたわりのないものから本物の芸術は生まれてこない。芸術だけではないのですが。 (山根 いずれにせよ作品にまとめるとか、彫刻に生かそうということで、お二人はデッサンをなさるわけですよね) まあそうですが。彫刻に生かそうというか、何か栄養を蓄積するようなことなんですよ。<中略> 素描