1. yayamamo

    No comment

    yayamamo
Changes in body
Source | HTML | Preview
@@ -1,152 +1,152 @@
手元のデータを<a href="https://www.wikidata.org/">Wikidata</a>のデータと照合させたいとき、すなわち、手元のデータをWikidataと関連付けてリンクを張りたいときに便利なツールとして<a href="http://openrefine.org/">OpenRefine</a>があります。本記事を執筆している時点でバージョン2.7が公開されており、Windows、Mac OS、Linux向けにそれぞれ実行ファイルが<a href="http://openrefine.org/download.html">配布されています</a>。OpenRefineの使い方は<a href="http://togotv.dbcls.jp/ja/20130212.html">統合TV</a>で紹介されていますので、こちらをご覧ください。
ここでは、このOpenRefineの提供する照合機能(Reconciliation、以下、照合機能)を用いて、Wikidataのデータと照合する方法を紹介します。OpenRefine開発陣によりGitHubで公開されている<a href="https://github.com/OpenRefine/OpenRefine/wiki/Reconciliation">英語の文書</a>を基にしています。OpenRefineはバージョン2.7からインターフェースの言語設定を切り替えられるようになったので、本記事では日本語のインターフェースを対象とした説明をしますが、初期設定では英語に設定されているので、日本語に切り替えましょう。その方法は次のとおりです。
1. トップページの左側に表示されているメニューのうち、「Language Settings」をクリックします。
![OR_LangEn.png](https://qiita-image-store.s3.amazonaws.com/0/119205/d0c902a3-2f4b-f13b-889f-6879dfa80ee7.png)
2. 「English」と表示されているセレクタを「日本語」にしてから、「Change Language」をクリックします。
![OR_LangJp.png](https://qiita-image-store.s3.amazonaws.com/0/119205/eda5ee96-d94e-8c08-bb04-f27b715cff28.png)
なお、日本語インターフェースではReconsiliationを「名寄せ」と表示しますので、OpenRefineの具体的な操作手順で表示内容に触れる場合には「名寄せ」と記述しますが、OpenRefineのReconciliationの機能としては「照合」の方が適切と感じられるので、原則として本記事では照合を使います。照合機能はテキストを半自動的にデータベースのID、もしくはキーとマッチさせます。機械による全自動ではマッチが不十分なことがあり、そのさいには人手を必要とするので、半自動的になります。たとえば、「Ocean's Eleven」という映画のタイトルに対しては、次のいずれかにマッチさせることになります。
* 1960年に公開された元タイトル(<a href="https://www.wikidata.org/wiki/Q464933">Wikidata項目Q464933</a>)
* 2001年にリメイクされた、ジョージクルーニーが主役を演じるタイトル(<a href="https://www.wikidata.org/wiki/Q205447">Wikidata項目Q205447</a>)
ここで「データベース」と呼ぶものは、より正確には「名称レジストリ」と呼んだ方が良いかもしれません。そして、「照合」は目新しい概念ではなく、常にそれが行われている分野もあります。たとえば警察が容疑者の名前を入手したさいには犯罪者データベースを当該名前で検索することでしょう。より詳細が分かれば容疑者の特定につながるかもしれません。
OpenRefineを用いることで、手持ちのデータに含まれる名称を、<a href="https://github.com/OpenRefine/OpenRefine/wiki/Reconciliation-Service-API">Reconciliation Service API</a>の仕様に従うウェブサービスを提供している任意のデータベースに対して照合できます。そして、Wikidataはそのようなウェブサービスを提供しているデータベースです。
#基本
OpenRefineで照合を行うには、列名の左側にあるアイコンをクリックして表示されるドロップダウンメニューから、「名寄せ」→「名寄せ開始...」の順に選択します。なお、この章で例示しているデータは<a href="http://www.nistep.go.jp/">科学技術・学術政策研究所(NISTEP)</a>が公開している「WoSCC-NISTEP大学・公的機関名辞書対応テーブル(ver.2017.1)
」の一部です。
<img width="380" alt="名寄せ1.png" src="https://qiita-image-store.s3.amazonaws.com/0/119205/0278cdb3-1af0-4980-1f9b-37ac8c017134.png">
対象になる列の一部のセルに対してだけ照合させたい場合は予めテキストフィルターやファセットを利用して絞っておきます。
続いて「名寄せ」ダイアログボックスの「サービス」エリアに「Wikidata Reconciliation for OpenRefine (ja)」が表示されていればそれを選択しますが、初めて本機能を使う場合には見つからないでしょう。その場合には、当該ダイアログボックス下部にある「標準サービスを追加」をクリックします。ここで「サービスのURLを入力」と書かれたポップアップウィンドウが現れるので、ここに「<a href="https://tools.wmflabs.org/openrefine-wikidata/ja/api">https://tools.wmflabs.org/openrefine-wikidata/ja/api</a>」を入力します。
<img width="260" alt="名寄せ2.png" src="https://qiita-image-store.s3.amazonaws.com/0/119205/47ef4746-e207-5009-7ad0-6c2615e9f00a.png">
![名寄せ3.png](https://qiita-image-store.s3.amazonaws.com/0/119205/92fecbb8-abf3-7e01-29fa-3693b1556b43.png)
より信頼性のある照合結果が得られるように、照合処理をするためのオプションが幾つか用意されています。これらは次の章以降で説明します。ダイアログボックス下部右側にある「名寄せ開始」ボタンをクリックすることで照合処理が始まります。照合対象となるデータのサイズに依存しますが、それなりの時間がかかります。現在、Wikidata照合サービスは一秒当たり大体3行処理します。処理が終わると結果が各セル内に表示されますが、問題なくマッチした場合と、幾つかの候補が表示される場合があります。
![名寄せ5.png](https://qiita-image-store.s3.amazonaws.com/0/119205/bf01711a-d3d1-04fa-3529-e1b875eff597.png)
・問題なくマッチした場合は、紺色のリンクが一つだけ表示されます。この場合は処理結果の正確性が高く、人手で改めて確認作業をする必要はありません
<img width="306" alt="名寄せ7.png" src="https://qiita-image-store.s3.amazonaws.com/0/119205/203b05bb-a5a8-a30d-6900-97c5337c3330.png">
・候補が幾つか表示された場合は、それぞれの照合度スコアが、淡青のリンクと共に表示されます。この場合は、候補の中から人手で適切なものを一つ選択する必要があります。選択するに当たり、その結果の適用方法を決めることができます。一つは、現在選択を行うセルにだけ選択結果を適用させるものであり、もう一つは、同じ名称が含まれる他の全てのセルに対しても同じ選択結果を適用させるものです。それぞれ、選択用のチェックボックス風のアイコンにマウスオーバーすると表示されるツールチップに「このトピックをこのセルにマッチ」、「このトピックを一致するすべてのセルにマッチ」と表示されます。
<img width="319" alt="名寄せ8.png" src="https://qiita-image-store.s3.amazonaws.com/0/119205/79fd9f36-a125-bc8a-0b84-b8bd575ae135.png">
照合されたセルの表示方法が変化することにくわえ、OpenRefineは二つのファセットを自動的に生成します。「judgement」と「best candidate's score」です。これにより、照合結果に基づいてセルをふるい分けられるようになります。マッチスコアが高い場合はそれだけ良いマッチが行われたことを意味するので、高スコアのセルだけを対象として、それらをすべて一括して承認することができます。具体的には、対象の列名の左側にあるアイコンをクリックして表示されるドロップダウンメニューから、「名寄せ」→「Actions」の順に選択します。
「judgement」ファセットを利用することで、マッチできなかったセルだけを表示させることができます。具体的には、当該ファセットで「none」をクリックします。表示されているセルに対して上述の選択処理を行うと、当該セルは「none」から「matched」に数えられることになるので、表示されなくなります。
#型でマッチを制限する
より良い照合結果を簡単に得るために、ある特定の型に照合対象を制限する方法があります。照合対象のデータが大学名であれば、「東京」は<a href="http://www.wikidata.org/entity/Q7842">東京大学(Q7842)</a>であるし、駅名であれば<a href="http://www.wikidata.org/entity/Q283196">東京駅(Q283196)</a>という具合です。
Wikidataでは型も項目の一つであり、<a href="http://www.wikidata.org/entity/Q283196">東京駅(Q283196)</a>は<a href="http://www.wikidata.org/entity/Q55488">鉄道駅(Q55488)</a>型を持つことが、<a href="http://www.wikidata.org/entity/P31">分類(P31)</a>プロパティを用いて記述されています。型はオントロジーの中で位置づけされ、<a href="http://www.wikidata.org/entity/P279">上位クラス(P279)</a>プロパティを用いて型と型の間の関係が定義されています。例えば、<a href="http://www.wikidata.org/entity/Q55488">鉄道駅(Q55488)</a>の上位クラスは<a href="http://www.wikidata.org/entity/Q719456">駅(Q719456)</a>になります。ある型のクラス関係を可視化したいときに便利なのが、<a href="https://angryloki.github.io/wikidata-graph-builder/">Wikidata Graph Builder</a>です。例えば、駅(Q719456)の下位のクラス一覧を<a href="https://angryloki.github.io/wikidata-graph-builder/?property=P279&item=Q719456&lang=ja&mode=reverse">可視化</a>できます。
![WikidataOntology.png](https://qiita-image-store.s3.amazonaws.com/0/119205/120ac4b3-9c7b-056a-5eab-a769e5f87b68.png)
名寄せダイアログでは型を指定することでき、指定したクラスおよびその下位クラスに含まれる項目にマッチ対象を制限できます。たとえば、駅(Q719456)を指定すれば、東京駅(Q283196)がマッチ可能になります。初期設定の状態でOpenRefineは与えられたデータの最初のいくつかをみて型を複数提案しますが、提案されたクラスは下位すぎることが多いことから、より上位のクラスを指定することで、より多くの項目をマッチ対象にできます。
Wikidataの項目にはどのクラスにも属していないものがあり、照合時にある特定のクラスを指定した場合にはそれらの項目は結果に含まれません。ただし、照合対象として指定したクラスに含まれる項目が何も見つからなかった場合には、どのクラスにも属していない項目がマッチすることがあります。それでもマッチスコアは低く、自動的にマッチすることはありません。
#プロパティを用いて改善する
-一般的に名称データはあいまいであることが多いですが、他の列の値をみることで適切な項目を特定できるかもしれません。照合用のインターフェースではそれらの列を考慮してマッチスコアに反映させる設定ができます。例えば、スポーツ選手名を第一列に、プレイするスポーツを第二列に含むデータセットがあったとします。
+一般的に名称データは曖昧であることが多いですが、他の列の値をみることで適切な項目を特定できるかもしれません。照合用のインターフェースではそれらの列を考慮してマッチスコアに反映させる設定ができます。例えば、スポーツ選手名を第一列に、プレイするスポーツを第二列に含むデータセットがあったとします。
![2017-07-07 (2) - コピー.png](https://qiita-image-store.s3.amazonaws.com/0/119205/eb08841f-9331-8937-1e93-b065eedc27f1.png)
第二列の値をこの目的に利用する場合には、これらの値がWikidataにおいてどのように表現されているのかを知る必要があります。すなわち、スポーツ選手とプレイするスポーツを結び付けているWikidataのプロパティを知る必要があります。<a href="http://www.wikidata.org/entity/Q1189">ウサイン・ボルト(Q1189)</a>選手についての項目を見ると、<a href="http://www.wikidata.org/entity/P641">スポーツプロパティ(P641)</a>が該当することが分かります。
名寄せダイアログの「他のカラムから関連する詳細を使用」と表示されているエリアで、対象となる列名(カラム)の右隣にあるチェックボックスをチェックし、さらに右隣にある入力ボックスに具体的なWikidataプロパティ名を入力します。
![2017-07-07 (3) - コピー.png](https://qiita-image-store.s3.amazonaws.com/0/119205/73e0fd61-c1fd-43df-1b7d-022c678bcf83.png)
照合処理は双方の列の値に対してファジーマッチを行います。
![2017-07-07 (5) - コピー.png](https://qiita-image-store.s3.amazonaws.com/0/119205/ee84fc55-1d71-b6b4-08f0-6eafa28b1ca3.png)
結果としてスポーツプロパティによるマッチがなされた項目についてはマッチスコアが高くなることが確認できます。
#プロパティパスを用いる(上級編)
<b>本機能はWikidataに対する照合インターフェースに特徴的なものです</b>
照合対象の列の値と、曖昧性を解消させるための列の値が直接的でない場合があります。すなわち、両者の間を結ぶプロパティがない場合です。例えば以下のように都市に関するデータを考えてみましょう。
![2017-07-07 (8) - コピー.png](https://qiita-image-store.s3.amazonaws.com/0/119205/73ffc94a-552c-27a1-7117-7635fa5805bc.png)
各都市名から対応する国コードを取得するには二つのプロパティを経由する必要があります。
最初に、<a href="https://www.wikidata.org/wiki/Property:P17">国(P17)</a>を辿ることで当該都市がある国に対する項目を取得し、続いて<a href="https://www.wikidata.org/wiki/Property:P297">国名コード(ISO 3166-1 alpha-2)(P297)</a>を辿ることで2文字の国名コードを示す文字列を取得します。
![WikidataOntology2.png](https://qiita-image-store.s3.amazonaws.com/0/119205/6b0926a1-8749-0cab-50af-8cbcd4b33bd4.png)
-れは<a href="https://www.w3.org/TR/sparql11-property-paths/">SPARQLのプロパティパス</a>の考えからヒントを得て考案されたもので、照合インターフェースを用いて、例えば、```P17/P297```のように、プロパティIDを順にスラッシュで区切りながら記述していくことで指定できます。
+のような場合に対処するために、<a href="https://www.w3.org/TR/sparql11-property-paths/">SPARQLのプロパティパス</a>の考えからヒントを得て考案された設定方法があります。すなわち、照合インターフェース、```P17/P297```のように、プロパティIDを順にスラッシュで区切りながら記述していくものです。
![2017-07-07 (10) - コピー.png](https://qiita-image-store.s3.amazonaws.com/0/119205/75d2e2bf-9691-ed27-c9c4-3cff51e9d5ac.png)
この追加的な情報を用いることで同名問題をある程度は解消できるようになります。「Cambridge, US」は依然として曖昧なので、完全マッチスコアをもつ複数の項目があります。しかし、「Oxford, GB」はうまく曖昧性が解消されていることが分かります。
![2017-07-07 (12) - コピー.png](https://qiita-image-store.s3.amazonaws.com/0/119205/fc52eae4-1b4e-b058-98b4-327453ea0077.png)
現在、エンドポイントでは```/```と```|```の2種類のプロパティ組み合わせ方法が提供されています。すなわち、前者は上述した通り、二つのパスを結合させ、後者は、両者のパスで得られる値の和集合を取得します。パスの結合を示すスラッシュの方が、和集合を示す縦棒よりも評価順序が高くなります。ドット文字の```.```は空のパスを示すために利用できます。例えば、以下のプロパティパスは全て等価です。
- ```P17|P749/P17```
- ```P17|(P749/P17)```
- ```(.|P749)/P17```
これらはみな、項目の<a href="http://www.wikidata.org/entity/P17">国</a>か、その<a href="http://www.wikidata.org/entity/P749">親会社</a>を取得します。
<h2>値を比較する</h2>
初期設定ではOpenRefineから与えられた値とWikidataにある値を文字列ベースのファジーマッチで比較されています。この原則に対する例外規定として以下の項目があります。
- 値が識別子の場合は完全文字列マッチが行われます。
- 値が整数値の場合は整数値同士の同値判定が行われます。
- 値が浮動小数点値の場合は、両者が同値の場合を100とし、両者の差の絶対値が大きくなるに従い0になるようなスコアになります。
- 値が位置情報(OpenRefineにおいては```"lat,lang"```形式で特定されます)の場合は、両者が同値の場合を100とし、両者の間の距離が離れるのに従い0になるようなスコアになります。現状では両者の間が1Kmを超えると0になります。
プロパティパスの最後に修飾子を追加することで、値の一部分にマッチさせられます。
- ```@lat```と```@lng```: 緯度と経度(浮動小数)
- ```@year```、```@month```、```@day```、```@hour```、```@minute```、```@second```: 日時の一部(整数)。Wikidataの値が適切な時のみ得られます。
- ```@isodate```: ISO形式(```1987-08-23```)で日にちを取得します(文字列)。常に値が得られます。
- ```@iso```: IOS形式(```1996-03-17T04:15:00+00:00```)で日時を取得します。値はUTC時間で常に得られます。
- ```@urlscheme ("https")```、```@netloc ("www.wikidata.org")```、```@urlpath ("/wiki/Q42")```: これらはそれぞれURLの該当部分を取得するのに使います。
たとえば、誕生日で人に関するデータを処理したいけれども、データとしては月と日しかない場合は、最初に月と日、それぞれの列を用意します。続いて、「他のカラムから関連する詳細を使用」において、各列につき、それぞれ、```SPARQL:P569@month```、```SPARQL:P569@day```として照合を開始します。
#ユニークな識別子を用いて照合する
Wikidataには多くの外部のユニークな識別子を含んでいます。もし照合しようとしているデータにこのような識別子が含まれている場合には正確な照合を行うために非常に有益となります。ユニークな識別子に対応するWikidataプロパティを指定することで、照合方法を変えることができるからです。最初に当該識別子を持つWikidataの項目を取得し、それに対して完全一致スコア(100)を与えます。他の全てのプロパティは考慮されませんし、照合しようとしている列の値をも同様に無視されます。もしも対応する項目が見つからない場合には、従来のマッチ方法に戻って処理します。
<b>注意点1</b>: 異なる複数のWikidata項目に、同一のユニークな識別子が割り当てられているときがあります。このような場合には、Wikidataのユニーク性の制限に違反することになるので、衝突としてWikidata側で判断されます。得られる結果は複数の項目が含まれることになりますが、自動的なマッチは行われません。
<b>注意点2</b>: Wikidataで表現されているのと全く同一のユニークな識別子を照合しようとしているデータに含めておく必要があります。識別子のマッチは厳格な文字列同値性で判断されます。大文字・小文字の違いや空白、冒頭のゼロなどもマッチ対象になります。詳細は関連するWikidataプロパティに関する文書を参照してください。
なお、このマッチ方法は、照合しようとしている列に含まれている識別子に対してだけ行われます。例えば、<a href="https://www.wikidata.org/wiki/Property:P297">国名コード(ISO 3166-1 alpha-2)(P297)</a>は国を識別するための識別子ですが、上記の例で示した```P17/P297```のようなプロパティパスを利用する場合ではユニークな識別子としては使われません。
一方で、ユニークな識別子の和集合は問題ありません。たとえば、DOIや、CiteCeerX IDを含む列がある場合を考えます。両者の間に表記上の曖昧性が互いに無いことを確認できれば、```(P356|P3784)```として表現されるプロパティ値との照合処理が行われます。各行について、DOIもしくはCiteCeerXにマッチさせるとともに、その他の値を無視します。
#照合したデータベースから値を取得する
あるデータセットを既存のデータベースと照合する理由として、特定のデータを当該データベースから取得してOpenRefineに流し込むことが考えられます。現状ではOpenRefineの照合インターフェースにそのような機能を実現する標準的な方法は提供されていません(<a href="https://github.com/OpenRefine/OpenRefine/issues/1179">議論はされている</a>ようです)。
この機能について、Wikidataに限れば対応方法があるようですが、現在、うまく動作確認できない(```label=false```とすればok)ので、割愛します。詳細は<a href="https://github.com/OpenRefine/OpenRefine/wiki/Reconciliation#fetching-values-from-the-reconciled-database">こちら</a>をご参照ください。要は、OpenRefineを利用して新規の列を作り、そこに他の列に含まれるWikidataの識別子を参照しつつ、所望のプロパティ値をWikidataから流し込むことができるという話になります。
#提示された案をすべて保持する
照合サービスの結果で得られたベストマッチだけを残すのではなく、すべての候補を維持するには、以下のようにします。
1. 照合処理を始める前に名寄せダイアログの下部にある「信頼性の高い候補をオートマッチ」のチェックを外します。
2. 照合処理が終わったのちに、照合を行った列の列名部分にあるアイコンをクリックして表示されるプルダウンメニューで「カラム編集」→「このカラムに基づいたカラムを追加…」の順に選択します。
1. 式の入力ボックスに```cell.recon.candidates[0].name```と入力します。なお、初期値としては```value```が入力されていると思います。
2. Wikidataへのリンクが欲しい場合には```cell.recon.candidates[0].id```と入力します。
3. 全ての候補の内部IDを列挙したい場合は```cell.recon.candidates.join(',')```と入力します。必要に応じて「Split multi-valued cells」を行います。
#言語を設定する
本記事ではWikidataの照合サービスのうち、言語設定が日本語のものを利用しましたが、ほかにも多くの言語設定が利用できます。照合サービスの言語設定を変えるには、まず、対象となる言語の2文字の言語コードを知る必要があります。そして、名寄せダイアログボックスの下部にある「標準サービスを追加」をクリックして所望のURLを追加します。フランス語の場合では言語コードがfrなので、```https://tools.wmflabs.org/openrefine-wikidata/fr/api```となります。このように、```api```の直前に言語コードを含めることで照合サービスの言語を設定します。
なお、照合時には設定された言語に関わらず文字列マッチを行うので、照合結果には影響を及ぼしません。言語設定を切り替える目的は、項目名やプロパティ名が当該言語に翻訳されている場合は、それを表示させることにあります。
#関連情報
- <a href="https://github.com/OpenRefine/OpenRefine/wiki/Variables">変数一覧</a>
- <a href="https://github.com/OpenRefine/OpenRefine/wiki/Reconcilable-Data-Sources">照合対象データベース</a>