Module:ChartConstant:修订间差异

来自Arcaea中文维基
无编辑摘要
(重写了重写了 vsc里一顿写之后预览一遍过给我自己都吓到了)
第8行: 第8行:
local function cv()
local function cv()
local list = {}
local list = {}
for i,k in pairs(songlist['songs'])
for i,k in pairs(songlist['songs']) do
do
list[k['id']] = {
list[k['id']] = { 
k['title_localized']['en'],
k['title_localized']['en'], 
k["date"],
k["date"],
nil,
nil,
nil
nil
}
}
if k["difficulties"][4] then
local byd = k["difficulties"][4]
if k["difficulties"][4]["title_localized"] then
if byd then
list[k['id']][3] = k["difficulties"][4]["title_localized"]["en"]
if byd["title_localized"] then
list[k['id']][3] = byd["title_localized"]["en"]
end
end
if k["difficulties"][4]["date"] then
if byd["date"] then
list[k['id']][4] = k["difficulties"][4]["date"]
list[k['id']][4] = byd["date"]
end
end
end
end
第29行: 第29行:




-- local specialSongNameConverter = {
function p.main()
-- ["#1f1e33"] = "#1f1e33",
 
--   ["AI[UE]OON"] = "AI[UE]OON",
--   ["Last | Eternity"] = "Last",
--   ["Last | Moment"] = "Last"
-- }
-- local n = {
--   ["Last | Eternity"] = "Last \| Eternity",
--   ["Last | Moment"] = "Last \| Moment"
-- }


function p.main()
local name, link, timestamp, index
local list = {}
local name, link
local cvList = cv()
local cvList = cv()
   local result = {}
   local mid_result = {}
local get_table_index = function(i)
if i>=11 then
return math.floor(i)
else return i end
end
    for i, k in pairs(chartConstantList) do
    for i, k in pairs(chartConstantList) do
   if k[2] or k[3] or k[4] then
 
   name = cvList[i][1]
name = cvList[i][1]
   end
link = name
timestamp = cvList[i][2]
 
      if trans["songNameToDisplayName"][name] then
      if trans["songNameToDisplayName"][name] then
        link = trans["songNameToDisplayName"][name]
        link = trans["songNameToDisplayName"][name]
else
link = name
      end
      end
      if trans["sameName"][name] then
      if trans["sameName"][name] then
   link = trans["sameName"][name][i]
   link = trans["sameName"][name][i]
   end
   end
-- if n[name] then
if cvList[i][4] then
-- name = n[name]
timestamp = cvList[i][4]
-- end
end
   if k[2] and tonumber(k[2]['constant'])>=8 and not(k[2]['old']) then
   table.insert(list, { i, name, k[2]['constant'], "PRS", link, cvList[i][2] })
   end
   if k[3] and tonumber(k[3]['constant'])>=8 and not(k[3]['old']) then
   table.insert(list, { i, name, k[3]['constant'], "FTR", link, cvList[i][2] })
   end
   if k[4] and tonumber(k[4]['constant'])>=8 and not(k[4]['old']) then
   if cvList[i][3] then
name = cvList[i][3]
end
if cvList[i][4] then
table.insert(list, { i, name, k[4]['constant'], "BYD", link, cvList[i][4] })
else
   table.insert(list, { i, name, k[4]['constant'], "BYD", link, cvList[i][2] })
end
   end
   end
  


-- make lists
for m, q in ipairs({ 2, 3, 4 }) do
   local result = {}
if k[q] and tonumber(k[q]["constant"])>=8 and not k[q]["old"] then
   local mid_result = {}
   result[11], result[12] = {}, {}
   mid_result[11], mid_result[12] = {}, {}


   for s, k in pairs(list) do
index = get_table_index(k[q]["constant"])
     if not(mid_result[k[3]]) then mid_result[k[3]]={} end
     if not mid_result[index] then mid_result[index] = {} end
     if k[3]>=11 then
       if k[3]>=12 then
         table.insert(mid_result[12], k)
       else
         table.insert(mid_result[11], k)
       end
     else table.insert(mid_result[k[3]], k) end
   end


table.insert(mid_result[index], { i, name, k[q]["constant"], ({"","PRS","FTR","BYD"})[q], link, timestamp })


   -- sort songs
end
   local diffConverter = { PRS=2, FTR=3, BYD=4 }
end
   for s, k in pairs(mid_result) do
     table.sort(k, function (a, b)
       if not(a[3]==b[3]) then
         return a[3]>b[3]
       end
return a[6]<b[6]
--[=[
       if not(diffConverter[a[4]]==diffConverter[b[4]]) then
         return diffConverter[a[4]]>diffConverter[b[4]]
       else return string.upper(a[2])<string.upper(b[2]) end
]=]
     end)
    end
    end


-- use template
-- use template
-- 组排单元 第一个参数是曲名,第二个是id,第三个是难度,link字面意思
-- 组排单元 第一个参数是曲名,第二个是id,第三个是难度,link字面意思
    for s, k in pairs(mid_result) do
    for s, k in pairs(mid_result) do
   if s<11 then
if not(result[s]) then result[s] = {} end
   if not(result[s]) then result[s]={} end
index = get_table_index(k[1][3])
       for n, m in pairs(k) do
 
         table.insert(result[s],mw.getCurrentFrame():expandTemplate { title = '组排单元', args = { m[2], m[1], m[4], link=m[5] } } )
table.sort(k,
       end
function (a, b)
   else
if a[3]~=b[3] then
   for n, m in pairs(k) do
return a[3]>b[3]
         table.insert(result[math.floor(s)],mw.getCurrentFrame():expandTemplate { title = '组排单元', args = { m[2], m[1], m[4], CC = string.format("%.1f", m[3]), link=m[5] } } )
end
       end
return a[6]<b[6]
   end
end)
 
for n, m in ipairs(k) do
local arguments = { m[2], m[1], m[4], link=m[5] }
if index >= 11 then arguments.CC = string.format("%.1f", m[3]) end
table.insert(result[index], mw.getCurrentFrame():expandTemplate { title = '组排单元', args = arguments })
end
    end
    end




-- sort constants
-- sort constants
local sortTable = {}
local sortedTable = {}
for i,k in pairs(result) do
for i,k in pairs(result) do
table.insert(sortTable, {i, k})
table.insert(sortedTable, {i, k})
end
end
table.sort(sortTable, function(a,b) return a[1] > b[1] end)
table.sort(sortedTable, function(a,b) return a[1] > b[1] end)




-- add head and end
-- add head and end
local finText = "<div class='notaninfobox dstable'>\n"
local finText = "<div class='notaninfobox dstable'>\n"
 
for i,k in ipairs(sortedTable) do
for i,k in ipairs(sortTable)
if k[1] == 11 or k[1] == 12 then
do
finText = finText 
if k[1] == 11 or k[1] == 12
.. "<div class='ds'>" .. k[1] .. "</div>\n"
then
.. "<div class='number'>" .. mw.getCurrentFrame():expandTemplate { title = '组排列', args = { ['高度']="154px"  }  }
finText = finText .. "<div class='ds'>"..k[1].."</div>\n"
.. table.concat(k[2]) .. mw.getCurrentFrame():expandTemplate { title = '组排列-end' } .. "</div>\n"
finText = finText .. "<div class='number'>"..mw.getCurrentFrame():expandTemplate { title = '组排列', args = { ['高度']="154px"  }  }
..table.concat(k[2])..mw.getCurrentFrame():expandTemplate { title = '组排列-end' }.."</div>\n"
else
else
finText = finText .. "<div class='ds'>"..string.format("%.1f", k[1]).."</div>\n"
finText = finText
finText = finText .. "<div class='number'>"..mw.getCurrentFrame():expandTemplate { title = '组排列' }
.. "<div class='ds'>" .. string.format("%.1f", k[1]).."</div>\n"
..table.concat(k[2])..mw.getCurrentFrame():expandTemplate { title = '组排列-end' }.."</div>\n"
.. "<div class='number'>" .. mw.getCurrentFrame():expandTemplate { title = '组排列' }
.. table.concat(k[2]) .. mw.getCurrentFrame():expandTemplate { title = '组排列-end' } .. "</div>\n"
end
end
end
end
finText = finText .. "</div>"
finText = finText .. "</div>"
    return finText
    return finText
end
end


return p
return p

2022年9月2日 (五) 23:21的版本

可在Module:ChartConstant/doc创建此模块的帮助文档

local p = {}
local chartConstantList = mw.text.jsonDecode(mw.getCurrentFrame():expandTemplate{ title = 'ChartConstant.json' })
local songlist = mw.text.jsonDecode(mw.getCurrentFrame():expandTemplate{ title = 'Songlist.json' })
local trans = mw.text.jsonDecode(mw.getCurrentFrame():expandTemplate{ title = 'Template:Transition.json' })



local function cv()
	local list = {}
	for i,k in pairs(songlist['songs']) do
		list[k['id']] = {
			k['title_localized']['en'],
			k["date"],
			nil,
			nil
		}
		local byd = k["difficulties"][4]
		if byd then
			if byd["title_localized"] then
				list[k['id']][3] = byd["title_localized"]["en"]
			end
			if byd["date"] then
				list[k['id']][4] = byd["date"]
			end
		end
	end
	return list
end


function p.main()


	local name, link, timestamp, index
	local cvList = cv()

    local result = {}
    local mid_result = {}
	
	local get_table_index = function(i)
		if i>=11 then
			return math.floor(i)
		else return i end
	end

    for i, k in pairs(chartConstantList) do

		name = cvList[i][1]
		link = name
		timestamp = cvList[i][2]

        if trans["songNameToDisplayName"][name] then
            link = trans["songNameToDisplayName"][name]
        end
        if trans["sameName"][name] then
	    	link = trans["sameName"][name][i]
	    end
		if cvList[i][4] then
			timestamp = cvList[i][4]
		end

		for m, q in ipairs({ 2, 3, 4 }) do
			if k[q] and tonumber(k[q]["constant"])>=8 and not k[q]["old"] then

				index = get_table_index(k[q]["constant"])
        		if not mid_result[index] then mid_result[index] = {} end

				table.insert(mid_result[index], { i, name, k[q]["constant"], ({"","PRS","FTR","BYD"})[q], link, timestamp })

			end
		end
    end

	-- use template
	-- 组排单元 第一个参数是曲名,第二个是id,第三个是难度,link字面意思
    for s, k in pairs(mid_result) do
		if not(result[s]) then result[s] = {} end
		index = get_table_index(k[1][3])

		table.sort(k,
			function (a, b)
				if a[3]~=b[3] then
					return a[3]>b[3]
				end
				return a[6]<b[6]
			end)

		for n, m in ipairs(k) do
			local arguments = { m[2], m[1], m[4], link=m[5] }
			if index >= 11 then arguments.CC = string.format("%.1f", m[3]) end
			table.insert(result[index], mw.getCurrentFrame():expandTemplate { title = '组排单元', args = arguments })
		end
    end


	-- sort constants
	local sortedTable = {}
	for i,k in pairs(result) do
		table.insert(sortedTable, {i, k})
	end
	table.sort(sortedTable, function(a,b) return a[1] > b[1] end)


	-- add head and end
	local finText = "<div class='notaninfobox dstable'>\n"
	for i,k in ipairs(sortedTable) do
		if k[1] == 11 or k[1] == 12 then
			finText = finText 
					.. "<div class='ds'>" .. k[1] .. "</div>\n"
					.. "<div class='number'>" .. mw.getCurrentFrame():expandTemplate { title = '组排列', args = { ['高度']="154px"  }  }
					.. table.concat(k[2]) .. mw.getCurrentFrame():expandTemplate { title = '组排列-end' } .. "</div>\n"
		else
			finText = finText
					.. "<div class='ds'>" .. string.format("%.1f", k[1]).."</div>\n"
					.. "<div class='number'>" .. mw.getCurrentFrame():expandTemplate { title = '组排列' }
					.. table.concat(k[2]) .. mw.getCurrentFrame():expandTemplate { title = '组排列-end' } .. "</div>\n"
		end
	end
	finText = finText .. "</div>"
    return finText
end

return p