Modul:Wikidata utilities: Unterschied zwischen den Versionen
KKeine Bearbeitungszusammenfassung |
(überarbeitet) |
||
| Zeile 67: | Zeile 67: | ||
function fw.getBestStatements( entity, p ) | function fw.getBestStatements( entity, p ) | ||
if type( entity ) == 'string' then | if type( entity ) == 'string' then | ||
return mw.wikibase.getBestStatements( entity, p ) | |||
else | else | ||
return entity:getBestStatements( p ) | |||
end | end | ||
end | end | ||
| Zeile 102: | Zeile 100: | ||
function fw.getValue( entity, p, catArray ) | function fw.getValue( entity, p, catArray ) | ||
if | local value = '' | ||
if entity and entity ~= '' and p and p ~= '' then | |||
value = getFirstValue( fw.getBestStatements( entity, p ) ) | |||
if value and catArray then | |||
catArray[ p ] = '' | |||
end | |||
value = value or '' | |||
value = '' | |||
end | end | ||
if catArray then | if catArray then | ||
| Zeile 120: | Zeile 116: | ||
function fw.getId( entity, p, catArray ) | function fw.getId( entity, p, catArray ) | ||
if | local value = '' | ||
if entity and entity ~= '' and p and p ~= '' then | |||
value = getFirstValue( fw.getBestStatements( entity, p ) ) | |||
if value then | |||
if catArray then catArray[ p ] = '' end | |||
value = value.id | |||
else | |||
value = '' | |||
end | |||
end | end | ||
if catArray then | if catArray then | ||
| Zeile 139: | Zeile 134: | ||
function fw.getValues( entity, p, count, catArray ) | function fw.getValues( entity, p, count, catArray ) | ||
if | local values = '', statements | ||
if entity and entity ~= '' and p and p ~= '' then | |||
statements = fw.getBestStatements( entity, p ) | |||
values = getNValues( statements, count or #statements ) | |||
if catArray and #values > 0 then catArray[ p ] = '' end | |||
end | end | ||
if catArray then | if catArray then | ||
return values, catArray | return values, catArray | ||
else | else | ||
| Zeile 154: | Zeile 147: | ||
end | end | ||
function fw.getValuesByLang( entity, p, count, lang ) | function fw.getValuesByLang( entity, p, count, lang, catArray ) | ||
if ( | local ar = '', statements, i, value | ||
if entity and entity ~= '' and p and p ~= '' then | |||
statements = fw.getBestStatements( entity, p ) | |||
ar = {} | |||
count = count or #statements | |||
if #statements > 0 and count > 0 then | |||
i = 0 | |||
repeat | |||
i = i + 1 | |||
if statements[ i ].mainsnak.snaktype == 'value' then | |||
value = statements[ i ].mainsnak.datavalue.value | |||
if value.language and lang == value.language then | |||
table.insert( ar, statements[ i ].mainsnak.datavalue.value.text ) | |||
end | |||
end | |||
until ( i >= #statements ) or ( #ar >= count ) | |||
end | |||
if catArray and #ar > 0 then catArray[ p ] = '' end | |||
end | end | ||
if catArray then | |||
return ar, catArray | |||
else | |||
return ar | return ar | ||
end | end | ||
end | end | ||
function fw.getValuesWithQualifierIds( entity, p, qualifierP, defaultId ) | function fw.getValuesWithQualifierIds( entity, p, qualifierP, defaultId, catArray ) | ||
local result = {} | local result = {}, statements, value, id, i, j | ||
if entity and entity ~= '' and p and p ~= '' and qualifierP and qualifierP ~= '' then | |||
statements = fw.getStatements( entity, p, nil ) | |||
if #statements > 0 then | |||
-- defaultId is used if a qualifier is missing | |||
if not defaultId or defaultId == '' or type( defaultId ) ~= 'string' then | |||
defaultId = 'unknown' | |||
end | |||
for i = 1, #statements, 1 do | |||
value = statements[ i ].mainsnak.datavalue.value | |||
id = defaultId | |||
if statements[ i ].qualifiers and statements[ i ].qualifiers[ qualifierP ] | |||
and ( #statements[ i ].qualifiers[ qualifierP ] > 0 ) then | |||
for j = 1, #statements[ i ].qualifiers[ qualifierP ], 1 do | |||
if statements[ i ].qualifiers[ qualifierP ][ j ].snaktype == 'value' then | |||
id = statements[ i ].qualifiers[ qualifierP ][ j ].datavalue.value.id | |||
if catArray then catArray[ p ] = '' end | |||
break | |||
end | |||
end | |||
end | end | ||
result[ id ] = value | |||
end | end | ||
end | end | ||
end | end | ||
if catArray then | |||
return result | return result, catArray | ||
else | |||
return result | |||
end | |||
end | end | ||
-- get values array for monolingual text | -- get values array for monolingual text | ||
function fw.getValuesWithLanguages( entity, p ) | function fw.getValuesWithLanguages( entity, p, catArray ) | ||
local result = {} | local result = {}, statements, hyphen, i, lng, value | ||
if entity and entity ~= '' and p and p ~= '' then | |||
statements = fw.getStatements( entity, p, nil ) | |||
if #statements > 0 and statements[ 1 ].mainsnak.datatype == 'monolingualtext' then | |||
if catArray then catArray[ p ] = '' end | |||
for i = 1, #statements, 1 do | |||
value = statements[i].mainsnak.datavalue.value | |||
lng = value.language | |||
hyphen = lng:find( '-' ) | |||
if hyphen then | |||
lng = lng:sub( 1, hyphen - 1 ) | |||
end | |||
if not result[ lng ] then result[ lng ] = value.text end | |||
end | |||
end | end | ||
end | end | ||
if catArray then | |||
return result | return result, catArray | ||
else | |||
return result | |||
end | |||
end | end | ||
| Zeile 317: | Zeile 321: | ||
function fw.getCategories( catArray, formatStr ) | function fw.getCategories( catArray, formatStr ) | ||
result = '' | result = '' | ||
if not catArray then return result end | |||
if | if not formatStr or formatStr == '' then | ||
for key, value in pairs( catArray ) do | formatStr = '[[Category:%s]]' | ||
end | |||
for key, value in pairs( catArray ) do | |||
result = result .. string.format( formatStr, key ) | |||
end | end | ||
return result | return result | ||
end | end | ||
return fw | return fw | ||
Version vom 18. Mai 2019, 08:11 Uhr
Die Dokumentation für dieses Modul kann unter Modul:Wikidata utilities/doc erstellt werden
local fw = {}
function fw.checkId( id ) -- only syntax check
if ( not id ) or ( type( id ) ~= 'string' ) or ( id == '' ) then
return ''
end
local i = id:upper()
if not mw.ustring.match( i, '^Q[%d]+$') then
if mw.ustring.match( i, '^[%d]+$') then -- only number
return 'Q' .. i
else -- invalid id
return ''
end
end
return i
end
function fw.getEntity( id )
local wrongQualifier = false
local entity = nil
local i = fw.checkId( id )
if i ~= '' then
-- expensive function call
entity = mw.wikibase.getEntity( i )
if not entity then
i = ''
wrongQualifier = true
end
else
if id ~= '' then wrongQualifier = true end
end
return i, entity, wrongQualifier
end
local function getFirstValue( statements )
if #statements == 0 then
return nil
end
for i = 1, #statements, 1 do
if statements[i].mainsnak.snaktype == 'value' then
return statements[i].mainsnak.datavalue.value
end
end
return nil
end
local function getNValues( statements, count )
local ar = {}
if count > #statements then count = #statements end
if ( #statements == 0 ) or ( count <= 0 ) then
return ar
end
local i = 0
repeat
i = i + 1
if statements[i].mainsnak.snaktype == 'value' then
table.insert( ar, statements[i].mainsnak.datavalue.value )
end
until ( i >= #statements ) or ( #ar >= count )
return ar
end
function fw.getBestStatements( entity, p )
if type( entity ) == 'string' then
return mw.wikibase.getBestStatements( entity, p )
else
return entity:getBestStatements( p )
end
end
function fw.getStatements( entity, p, count )
local ar = {}
if ( not entity ) or ( entity == '' ) then
return ar
end
local statements = fw.getBestStatements( entity, p )
count = count or #statements
if count > #statements then count = #statements end
if ( #statements == 0 ) or ( count <= 0 ) then
return ar
end
local i = 0
repeat
i = i + 1
if statements[i].mainsnak.snaktype == 'value' then
table.insert( ar, statements[i] )
end
until ( i >= #statements ) or ( #ar >= count )
return ar
end
function fw.getValue( entity, p, catArray )
local value = ''
if entity and entity ~= '' and p and p ~= '' then
value = getFirstValue( fw.getBestStatements( entity, p ) )
if value and catArray then
catArray[ p ] = ''
end
value = value or ''
end
if catArray then
return value, catArray
else
return value
end
end
function fw.getId( entity, p, catArray )
local value = ''
if entity and entity ~= '' and p and p ~= '' then
value = getFirstValue( fw.getBestStatements( entity, p ) )
if value then
if catArray then catArray[ p ] = '' end
value = value.id
else
value = ''
end
end
if catArray then
return value, catArray
else
return value
end
end
function fw.getValues( entity, p, count, catArray )
local values = '', statements
if entity and entity ~= '' and p and p ~= '' then
statements = fw.getBestStatements( entity, p )
values = getNValues( statements, count or #statements )
if catArray and #values > 0 then catArray[ p ] = '' end
end
if catArray then
return values, catArray
else
return values
end
end
function fw.getValuesByLang( entity, p, count, lang, catArray )
local ar = '', statements, i, value
if entity and entity ~= '' and p and p ~= '' then
statements = fw.getBestStatements( entity, p )
ar = {}
count = count or #statements
if #statements > 0 and count > 0 then
i = 0
repeat
i = i + 1
if statements[ i ].mainsnak.snaktype == 'value' then
value = statements[ i ].mainsnak.datavalue.value
if value.language and lang == value.language then
table.insert( ar, statements[ i ].mainsnak.datavalue.value.text )
end
end
until ( i >= #statements ) or ( #ar >= count )
end
if catArray and #ar > 0 then catArray[ p ] = '' end
end
if catArray then
return ar, catArray
else
return ar
end
end
function fw.getValuesWithQualifierIds( entity, p, qualifierP, defaultId, catArray )
local result = {}, statements, value, id, i, j
if entity and entity ~= '' and p and p ~= '' and qualifierP and qualifierP ~= '' then
statements = fw.getStatements( entity, p, nil )
if #statements > 0 then
-- defaultId is used if a qualifier is missing
if not defaultId or defaultId == '' or type( defaultId ) ~= 'string' then
defaultId = 'unknown'
end
for i = 1, #statements, 1 do
value = statements[ i ].mainsnak.datavalue.value
id = defaultId
if statements[ i ].qualifiers and statements[ i ].qualifiers[ qualifierP ]
and ( #statements[ i ].qualifiers[ qualifierP ] > 0 ) then
for j = 1, #statements[ i ].qualifiers[ qualifierP ], 1 do
if statements[ i ].qualifiers[ qualifierP ][ j ].snaktype == 'value' then
id = statements[ i ].qualifiers[ qualifierP ][ j ].datavalue.value.id
if catArray then catArray[ p ] = '' end
break
end
end
end
result[ id ] = value
end
end
end
if catArray then
return result, catArray
else
return result
end
end
-- get values array for monolingual text
function fw.getValuesWithLanguages( entity, p, catArray )
local result = {}, statements, hyphen, i, lng, value
if entity and entity ~= '' and p and p ~= '' then
statements = fw.getStatements( entity, p, nil )
if #statements > 0 and statements[ 1 ].mainsnak.datatype == 'monolingualtext' then
if catArray then catArray[ p ] = '' end
for i = 1, #statements, 1 do
value = statements[i].mainsnak.datavalue.value
lng = value.language
hyphen = lng:find( '-' )
if hyphen then
lng = lng:sub( 1, hyphen - 1 )
end
if not result[ lng ] then result[ lng ] = value.text end
end
end
end
if catArray then
return result, catArray
else
return result
end
end
local function getValueFromDatavalue( datavalue )
local v = datavalue.value
local t = datavalue.type
if type( v ) == 'table' then
-- items which can be reduced to a string
if t == 'wikibase-entityid' then v = v.id
elseif t == 'time' then v = v.time
end
end
return v, t
end
-- The following function is an experimental one, not for extensive use
function fw.getValuesWithQualifiers( entity, p, qualifiers, count )
local result = {}
local statements = fw.getStatements( entity, p, count )
if #statements == 0 then return result end
if qualifiers and ( type( qualifiers ) == 'string' ) then
qualifiers = { qualifiers }
end
local array, key, value, i, j
for i = 1, #statements, 1 do
array = { value = statements[i].mainsnak.datavalue.value,
['value-type'] = statements[i].mainsnak.datavalue.type }
if statements[i].qualifiers then
if not qualifiers then -- all qualifier properties
for key, value in pairs( statements[i].qualifiers ) do
if #value > 0 then
for j = 1, #value, 1 do
if value[ j ].snaktype == 'value' then
array[ key ], array[ key .. '-type' ] =
getValueFromDatavalue( value[ j ].datavalue )
break
end
end
end
end
else -- table of selected qualifier properties
for key, value in pairs( qualifiers ) do
if statements[i].qualifiers[ value ] and
( #statements[i].qualifiers[ value ] > 0 ) then
for j = 1, #statements[i].qualifiers[ value ], 1 do
if statements[i].qualifiers[ value ][ j ].snaktype == 'value' then
array[ value ], array[ value .. '-type' ] =
getValueFromgetValueFromDatavalue( statements[i].qualifiers[ value ][ j ].datavalue )
break
end
end
end
end
end
end
table.insert( result, array )
end
return result
end
function fw.typeSearch( p31, list, limit, catArray )
-- p31: array of Wikidata values
-- list: array of q id - types relations
-- limit: maximum levels to analyse
if (not p31) or (#p31 == 0) then return 'error', catArray end
local aType, i, id, j
for i = 1, #p31, 1 do
id = p31[i].id
aType = list[id]
if aType then
return aType, catArray
else
j = 0
repeat
id, catArray = fw.getId( id, 'P279', catArray )
if id ~= '' then
aType = list[id]
if aType then return aType, catArray end
end
j = j + 1
until (j >= limit) or (id == '')
end
end
return 'error', catArray
end
function fw.getCategories( catArray, formatStr )
result = ''
if not catArray then return result end
if not formatStr or formatStr == '' then
formatStr = '[[Category:%s]]'
end
for key, value in pairs( catArray ) do
result = result .. string.format( formatStr, key )
end
return result
end
return fw