モジュール:学校コード検査

モジュールの解説[作成]
local p = {}
function p.Main( frame )
	-- 何も入力されてない場合、何も返さない
	if frame.args[1] == nil or frame.args[1] == "" then
		return ""
	else
	local targetid = frame.args[1]
	
	-- アルファベット大文字1 + 半角数字12桁から構成されているか確認
	if #targetid == 13 and string.match( targetid , "%u%d%d%d%d%d%d%d%d%d%d%d%d" ) ~= nil then
		-- それら13桁を分割
		local c_type = string.sub( targetid , 1 , 2 )
		local c_pref = string.sub( targetid , 3 , 4 )
		local c_div = string.sub( targetid , 5 , 5 )
		local c_scnf = string.sub( targetid , 6 , 6 )
		local c_ckd = string.sub( targetid , 13 , 13 )
		
		-- 最初2桁が「学校種」のいずれかに合致するか確認
		if ( c_type == "A1" or c_type == "A2" or c_type == "B1" or c_type == "C1" or c_type == "C2" or c_type == "D1" or c_type == "D2" or c_type == "E1" or c_type == "F1" or c_type == "F2" or c_type == "G1" or c_type == "H1" or c_type == "H2" ) and
		-- 3~4桁目が都道府県番号01~47のいずれかに合致するか確認
		( string.match( c_pref , "0[1-9]" ) ~= nil or string.match( c_pref , "[1-3][0-9]" ) ~= nil or string.match( c_pref , "4[0-7]" ) ~= nil ) and
		-- 5桁目が「設置区分」1〜3のいずれかに合致するか確認
		( c_div == "1" or c_div == "2" or c_div == "3" ) and
		-- 学校番号の確認。2桁目以降の数字に制限はないため、1桁目が0でないことのみ確認
		c_scnf ~= "0" then
			
			-- 検査数字の確認
			local ck_1 = 0
			local ck_2 = ""
				if string.sub( targetid , 1 , 1 ) == "A" then
					ck_2 = 1
				elseif string.sub( targetid , 1 , 1 ) == "B" then
					ck_2 = 2
				elseif string.sub( targetid , 1 , 1 ) == "C" then
					ck_2 = 3
				elseif string.sub( targetid , 1 , 1 ) == "D" then
					ck_2 = 4
				elseif string.sub( targetid , 1 , 1 ) == "E" then
					ck_2 = 5
				elseif string.sub( targetid , 1 , 1 ) == "F" then
					ck_2 = 6
				elseif string.sub( targetid , 1 , 1 ) == "G" then
					ck_2 = 7
				elseif string.sub( targetid , 1 , 1 ) == "H" then
					ck_2 = 8
				end
			local ck_3 = tonumber( string.sub( targetid , 2 , 2 ) )
			local ck_4 = tonumber( string.sub( targetid , 3 , 3 ) )
			local ck_5 = tonumber( string.sub( targetid , 4 , 4 ) )
			local ck_6 = tonumber( string.sub( targetid , 5 , 5 ) )
			local ck_7 = tonumber( string.sub( targetid , 6 , 6 ) )
			local ck_8 = tonumber( string.sub( targetid , 7 , 7 ) )
			local ck_9 = tonumber( string.sub( targetid , 8 , 8 ) )
			local ck_10 = tonumber( string.sub( targetid , 9 , 9 ) )
			local ck_11 = tonumber( string.sub( targetid , 10 , 10 ) )
			local ck_12 = tonumber( string.sub( targetid , 11 , 11 ) )
			local ck_13 = tonumber( string.sub( targetid , 12 , 12 ) )
			
			local ckd_1 = ck_1
			local ckd_2 = ""
			local ckd_3 = ck_3
			local ckd_4 = ""
			local ckd_5 = ck_5
			local ckd_6 = ""
			local ckd_7 = ck_7
			local ckd_8 = ""
			local ckd_9 = ck_9
			local ckd_10 = ""
			local ckd_11 = ck_11
			local ckd_12 = ""
			local ckd_13 = ck_13
			
			if ck_2 * 2 >= 10 then
				ckd_2 = ck_2 * 2 - 9
			else
				ckd_2 = ck_2 * 2
			end
			
			if ck_4 * 2 >= 10 then
				ckd_4 = ck_4 * 2 - 9
			else
				ckd_4 = ck_4 * 2
			end

			if ck_6 * 2 >= 10 then
				ckd_6 = ck_6 * 2 - 9
			else
				ckd_6 = ck_6 * 2
			end

			if ck_8 * 2 >= 10 then
				ckd_8 = ck_8 * 2 - 9
			else
				ckd_8 = ck_8 * 2
			end

			if ck_10 * 2 >= 10 then
				ckd_10 = ck_10 * 2 - 9
			else
				ckd_10 = ck_10 * 2
			end

			if ck_12 * 2 >= 10 then
				ckd_12 = ck_12 * 2 - 9
			else
				ckd_12 = ck_12 * 2
			end
			
			local ckd_sum = ckd_1 + ckd_2 + ckd_3 + ckd_4 + ckd_5 + ckd_6 + ckd_7 + ckd_8 + ckd_9 + ckd_10 + ckd_11 + ckd_12 + ckd_13
			local ckd_mod = ckd_sum % 10
			local ckd_result = ""
			if ckd_mod == 0 then
				ckd_result = 0
			else
				ckd_result = 10 - ckd_mod
			end
			
			if ckd_result == tonumber( c_ckd ) then
				return frame.args[1]
			else
				return "[[Category:Infoboxに不備のある学校記事]]"
			end
		else
			return "[[Category:Infoboxに不備のある学校記事]]"
		end
	else
		return "[[Category:Infoboxに不備のある学校記事]]"
	end
	end
end
return p