Skip to content

Navid2zp/go-wikidata

Repository files navigation

go-wikidata

GoDoc Build Go Report Card GitHub license

Wikidata API bindings in golang.

This package is suitable for retrieving data from wikidata database using its public API. Methods for updating, editing and adding to wikidata are not implemented (yet).

Read more about wikidata API: https://www.wikidata.org/w/api.php

Contents

Install

go get github.com/Navid2zp/go-wikidata

Get Entities

// Create a request
req, err := gowikidata.NewGetEntities([]string{"Q1"})

// Configurations such as props, sites and etc.
req.SetSites([]string{"enwiki", "fawiki"})

// Call get to make the request based on the configurations
res, err := req.Get()
Get entity methods:

Request methods:

// Param: props
// Default: info|sitelinks|aliases|labels|descriptions|claims|datatype
req.SetProps([]string{"info", "claims"})

// Param: sites
req.SetSites([]string{"enwiki", "fawiki"})

// Param: sitefilter
req.SetSiteFilter([]string{"enwiki", "fawiki"})

// Param: normalize
req.SetNormalize(true)

// Param: languagefallback
req.SetLanguageFallback(true)

// Param: languages
req.SetLanguages([]string{"en", "fa"})

// Param: redirects
req.SetRedirects(true)

// Param: titles
req.SetTitles([]string{"title", "another"})


// Method chaining is also supported
req.SetNormalize(true).SetSites([]string{"enwiki", "fawiki"})

Response methods:

claimReq, err := res["Q1"].NewGetClaims()

Same as calling NewGetClaims. See "Get Claims" for more information.

Get Claims

// Create a request
// You must either provide entity id or a claim GUID
req, err := gowikidata.NewGetClaims("Q1", "")

// Call get to make the request based on the configurations
res, err := req.Get()

You can also call NewGetClaims on Entity type.

Get claims methods:

Request methods:

// Param: props
// Default: references
req.SetProps([]string{"references"})

// Param: rank
// One of the following values: deprecated, normal, preferred
req.SetRank("normal")

// Param: property
req.SetProperty("P31")

Search

// Create a request
// Both search and language are required
req, err := gowikidata.NewSearch("abc", "en")

// Call get to make the request based on the configurations
res, err := req.Get()
Search methods:

Request methods:

// Param: props
// Default: url
req.SetProps([]string{"url"})

// Param: limit
// Default: 7
req.SetLimit(10)

// Param: strictlanguage
req.SetStrictLanguage(true)

// Param: type
// One of the following values: item, property, lexeme, form, sense
// Default: item
req.SetType("item")

// Param: continue
// Default: 0
req.SetContinue(7)

Response methods:

// Next page of results
// new coninue = limit + previous continue value
nextPage, err := res.Next()

Get Wikipedia Page Item

Find Wikipedia page item ID in wikidata by page slug (https://en.wikipedia.org/wiki/[SLUG]).

wikiDataID, err := gowikidata.GetPageItem("Earth")
fmt.Println(wikiDataID) // "Q2"

Get Available Badges

badges, err := gowikidata.GetAvailableBadges()

License

MIT