local p = {}
-- Non-non dynamic module, no inputs ▼
-- Utility function to clean up number strings by removing commas
local function cleanNumberString(value)
if type(value) == "string" then
return value:gsub(",", "")
return value
end
▲-- Non-dynamic module, no inputs
function p.main()
-- Returnsreturns only directly needed parametersparameter needed for the row,
-- other parameters are determined by subqueries of chained pages
local query = {
'[[-Sold item::~*]]',
'?=Name',
'?-Sold item.Shop sell price=ShopValue',
'?Value=InfoboxValue',
'limit = 10000500',
}
'order = asc'
}
local results = mw.smw.ask(query)
local out = {}
for _, item in ipairs(results) do ▼
local shopValues = item.ShopValue -- Could be an array or a single value
if shopValues ~= nil then
if type(shopValues) == "string" then
shopValues = { shopValues } -- Normalize to a table for consistency
end
local infoboxValueout = item.InfoboxValue{}
▲ for _, item in ipairs(results) do
if infoboxValue == nil then
if not(tonumber(item.ShopValue)==tonumber(item.InfoboxValue)) then
infoboxValue = 0
table.insert(out, item .Name) ▼
elseif type(infoboxValue)=='string' then
infoboxValue = tonumber(cleanNumberString(item.InfoboxValue))
end
local hasMismatch = false
return table.concat(out, '<br>')
for _, shopValue in ipairs(shopValues) do
if shopValue ~= "N/A" then
-- Compare numeric values
local cleanShopValue = cleanNumberString(shopValue)
local numericShopValue = tonumber(cleanShopValue)
if numericShopValue and numericShopValue ~= infoboxValue then
hasMismatch = true
break
end
end
end
-- Add the item to the output if any shopValue mismatched InfoboxValue
if hasMismatch then
▲ table.insert(out, item)
end
end
end
-- Format the output to display each item's details
local output = {}
for _, item in ipairs(out) do
table.insert(output, mw.text.jsonEncode(item)) -- Convert each item to a JSON string for display
end
return table.concat(output, '<br>') -- Concatenate the JSON representations with a line break
end
|