2012-03-08 6 views
3

私はopendataで新しく、何か助けが必要です。ウィキペディアはこのURLにsparqlエンドポイントを持っています: http://dbpedia.org/sparql dbpediaからいくつかのrdfファイルを取得するにはwebserviceを書く必要があります。 rdfファイルを取得するには、このエンドポイントに何を送信する必要がありますか? thx for helpsparqlエンドポインダからrdfファイルを取得する方法

答えて

9

CONSTRUCTクエリを送信します。小さな例:

WHERE句は、SELECTの場合と同じように、値がCONSTRUCTブロックを一種のテンプレートとして埋めます。非常に柔軟性があります。ここでステートメントをコピーするか、まったく別の形に変換することができます。

+0

hmxxとは何ですか?s?pと?oはどういう意味ですか? – hudi

+0

dbpediaからすべてのrdfファイルを返すここにsparqlを書くことができますか? – hudi

+2

@hudiあなたがSPARQLを使い始めたようですが、http://www.cambridgesemantics.com/2008/09/sparql-by-example/のような一般的なチュートリアルを読んでみてください? – RobV

2

Bob DuCharmeさんの"Learning SPARQL"本を読むことをお勧めします。 DBPediaエンドポイントを使用するいくつかの例についても説明します。

PS:ウィキペディアのSPARQLエンドポイントではありません - それはDBPedia SPARQLエンドポイントです(Wikipedia自体は独自のSPARQLエンドポイントATMを提供しません)。しかし、DBPediaのデータはWikipediaのデータに依存しています;)

+0

はいあなたは正しいです – hudi

4

Dannyが答えたのは正しい一般的な答えです。しかし、結果を得るために期待される時間のために、外部サービスに対してこのようなクエリを実行することはお勧めしません。の

from SPARQLWrapper import SPARQLWrapper, XML 

uri = "http://dbpedia.org/resource/Asturias" 
query = "CONSTRUCT { <%s> ?p ?o } WHERE { <%s> ?p ?o }" % (uri, uri) 

sparql = SPARQLWrapper("http://dbpedia.org/sparql") 
sparql.setQuery(query) 
sparql.setReturnFormat(XML) 
results = sparql.query().convert() 

file = open("output.rdf", "w") 
results.serialize(destination=file, format="xml") 
file.flush() 
file.close() 

:あなたは、コードは次のようになり、手動でインスタンスのためのPythonで、クエリ結果を保存する必要がなく、直接それを行うしたい場合は、具体的なリソース

上しかし、もちろん、それを行いますもちろん、これはほとんどのプログラミング言語で行うことができます。

+0

どのSPARQL 1.1準拠の実装でも[DESCRIBE](https: /www.w3.org/TR/sparql11-query/#describe)クエリ: 'DESCRIBE '。 – wikier

+0

私はあなたにローカルでrdfの保存に関する1つの質問をすることができますか?私はちょうどresults.serialize(destination = path、format = "xml"),,,,, use file = open(....... "w").......ファイルを使っています.close()...あなたの答えは私が問題を解決するのに役立ちます。私はその違いを知りたいです。 – bob90937