Skip to content

Latest commit

 

History

History
147 lines (120 loc) · 4.64 KB

README.md

File metadata and controls

147 lines (120 loc) · 4.64 KB

tansakusuR

A wrapper for SPARQL endpoints

Installation

You can install the development version of “tansakusuR” from GitHub with:

library(devtools)
install_github("UTNAK/tansakusuR")

Usage

library(tansakusuR)
endpoint_url <- "https://query.wikidata.org/sparql"


query_string <-'
SELECT ?spaceProbeLabel ?date ?picture
WHERE
{
  ?spaceProbe wdt:P31 wd:Q26529;
        wdt:P18 ?picture;
        wdt:P619 ?date . #mandatory
  SERVICE wikibase:label {
    bd:serviceParam wikibase:language "fr,en" .
  }
}
ORDER BY ?date
LIMIT 10
'

df <- send_query(endpoint_url, query_string)

Here is the queried result

df
#> # A tibble: 10 × 3
#>    date                 picture                                  spaceProbeLabel
#>    <chr>                <chr>                                    <chr>          
#>  1 1958-08-17T00:00:00Z http://commons.wikimedia.org/wiki/Speci… Pioneer 0      
#>  2 1958-10-11T00:00:00Z http://commons.wikimedia.org/wiki/Speci… Pioneer 1      
#>  3 1958-11-08T00:00:00Z http://commons.wikimedia.org/wiki/Speci… Pioneer 2      
#>  4 1958-12-06T00:00:00Z http://commons.wikimedia.org/wiki/Speci… Pioneer 3      
#>  5 1959-03-03T00:00:00Z http://commons.wikimedia.org/wiki/Speci… Pioneer 4      
#>  6 1959-11-26T00:00:00Z http://commons.wikimedia.org/wiki/Speci… Pioneer P-3    
#>  7 1960-03-11T00:00:00Z http://commons.wikimedia.org/wiki/Speci… Pioneer 5      
#>  8 1960-09-25T00:00:00Z http://commons.wikimedia.org/wiki/Speci… Pioneer P-30   
#>  9 1960-10-10T00:00:00Z http://commons.wikimedia.org/wiki/Speci… Mars 1M No.1   
#> 10 1960-12-15T00:00:00Z http://commons.wikimedia.org/wiki/Speci… Pioneer P-31

You can visualize the queried result as follows;

library(DT)
datatable(df)

Visualize as a table

Visualize as a table

Usage#2: Using .sparql file

library(tansakusuR)

sparqlfile="./examplequery.sparql"
endpoint_url <- "https://query.wikidata.org/sparql"
df <- send_query_from_file(endpoint_url, sparqlfile)
df
#> # A tibble: 10 × 3
#>    date                 picture                                  spaceProbeLabel
#>    <chr>                <chr>                                    <chr>          
#>  1 1958-08-17T00:00:00Z http://commons.wikimedia.org/wiki/Speci… Pioneer 0      
#>  2 1958-10-11T00:00:00Z http://commons.wikimedia.org/wiki/Speci… Pioneer 1      
#>  3 1958-11-08T00:00:00Z http://commons.wikimedia.org/wiki/Speci… Pioneer 2      
#>  4 1958-12-06T00:00:00Z http://commons.wikimedia.org/wiki/Speci… Pioneer 3      
#>  5 1959-03-03T00:00:00Z http://commons.wikimedia.org/wiki/Speci… Pioneer 4      
#>  6 1959-11-26T00:00:00Z http://commons.wikimedia.org/wiki/Speci… Pioneer P-3    
#>  7 1960-03-11T00:00:00Z http://commons.wikimedia.org/wiki/Speci… Pioneer 5      
#>  8 1960-09-25T00:00:00Z http://commons.wikimedia.org/wiki/Speci… Pioneer P-30   
#>  9 1960-10-10T00:00:00Z http://commons.wikimedia.org/wiki/Speci… Mars 1M No.1   
#> 10 1960-12-15T00:00:00Z http://commons.wikimedia.org/wiki/Speci… Pioneer P-31

You can see the SPARQL code using show_query().

show_query(sparqlfile)
#> SELECT ?spaceProbeLabel ?date ?picture
#> WHERE
#> {
#>   ?spaceProbe wdt:P31 wd:Q26529;
#>         wdt:P18 ?picture;
#>         wdt:P619 ?date . #mandatory
#>   SERVICE wikibase:label {
#>     bd:serviceParam wikibase:language "fr,en" .
#>   }
#> }
#> ORDER BY ?date
#> LIMIT 10

usage#3: Using send_update

Sample use case is from kepler16b-using-imce-vocabulary.

endpoint_url <- "http://localhost:3030/tutorial2-tdb/"
query_string <- '
PREFIX owl: <http://www.w3.org/2002/07/owl#>
PREFIX base:        <http://imce.jpl.nasa.gov/foundation/base#>
PREFIX mission:        <http://imce.jpl.nasa.gov/foundation/mission#>
PREFIX analysis:        <http://imce.jpl.nasa.gov/foundation/analysis#>
PREFIX sa:        <http://example.com/tutorial2/vocabulary/stateanalysis#>

delete {
  graph <http://example.com/tutorial2/description/statedictionary> {
    ?analysisTarget sa:hasStateValue ?beforeValue .
  }
}

where{
    BIND(<http://example.com/tutorial2/description/statedictionary#orbiter-spacecraft.isp> AS ?analysisTarget)
    BIND("3000" AS ?afterValue) 

        ?analysisTarget a owl:NamedIndividual ;
                sa:hasStateValue ?beforeValue .
}
'
send_update(endpoint_url, query_string)
#> [1] "{ \n  \"statusCode\" : 200 ,\n  \"message\" : \"Update succeeded\"\n}\n"