置顶公告:【置顶】关于临时开启评论区所有功能的公告(2022.10.22) | 【置顶】关于本站Widget恢复使用的公告
  • 你好~!欢迎来到萌娘百科镜像站!如需查看或编辑,请联系本站管理员注册账号。
  • 本镜像站和其他萌娘百科的镜像站无关,请注意分别。

Module:ReplacePlus

猛汉♂百科,万男皆可猛的百科全书!转载请标注来源页面的网页链接,并声明引自猛汉百科。内容不可商用。
跳到导航 跳到搜索
Template-info.svg 模块文档  [创建] [刷新]
local module = {}

local getArgs = require('Module:Arguments').getArgs

function _main(args, frame)
	local str = args['str'] or args[1] or ''
	local ptn = args['ptn'] or args[2] or ''
	ptn = mw.text.decode(mw.text.unstripNoWiki(ptn))
	local replace = args['rep'] or args[3] or ''
	local split = args['spl'] or args[4] or '、'
	local limit = args['lim'] or args[5] or 'false'
	local origin = tonumber(args['ori'] or args[6] or 1)
	local noprint = args['noprint'] or false
	
	str = mw.ustring.sub(str, origin)
	
	local captures = {}
	local result, count = ''
	
	if string.find(limit, '%d+') then
		limit = tonumber(limit)
		result, count = mw.ustring.gsub(str, ptn, function(s)
			captures[#captures + 1] = s
			return s
		end, limit)
		result = mw.ustring.gsub(str, ptn, replace, limit)		
	else
		result, count = mw.ustring.gsub(str, ptn, function(s)
			captures[#captures + 1] = s
			return s
		end)
		result = mw.ustring.gsub(str, ptn, replace)		
	end
	
	frame:callParserFunction('#vardefine', 'result.capture', table.concat(captures, split))
	frame:callParserFunction('#vardefine', 'result.count', count)
	
	if noprint ~= 'true' then
		return result		
	else
		frame:callParserFunction('#vardefine', 'result', result)
		return ''
	end
end

function module.main(frame)
	local args = getArgs(frame)
	return _main(args, frame)
end

function module.multi(frame)
	local args = getArgs(frame, { warppers = 'Template:Str_replace_multi' } )
	local text = args[1] or ''
	local done = {}
	if args[2] then
		local sort = mw.text.split(mw.ustring.gsub(args[2], '|+', '|'), '|')
		while sort[#sort] == '' do
			table.remove(sort, #sort)
		end
		for _, key in ipairs(sort) do
			if key ~= 1 and key ~= 2 then
				text = mw.ustring.gsub(text, key, args[key])
			end
			done[key] = true
		end
	end
	-- 允许对顺序不依赖的情况直接使用模块
	for key, val in pairs(args) do
		if not done[key] and key ~= 1 and key ~= 2 then
			text = mw.ustring.gsub(text, key, val)
		end
	end
	return text
end

return module