-- 6. 实现一个 replaceWords(s, dict),支持根据字典批量替换单词。
-- 输入:"Lua is fun", {Lua="C#", fun="great"}
-- 输出:"C# is great"
local function replaceWords(s, dict) local newStr = s local count = 0 for i, v in pairs(dict) do newStr,count = newStr:gsub(i, v) end return newStr end
-- 7. 将驼峰命名(camelCase)转换为下划线命名(camel_case)
local function renameToUnderLine(s) local newStr, count = s:gsub("%u", function(ch) return "_" .. ch:lower() end) return newStr end print(renameToUnderLine("camelCase"))
-- 8. 实现一个函数,将字符串中的所有数字替换成相同数量的 *。
-- 输入:"Lua123Code"
-- 输出:"Lua***Code"
local function numberToStar(s) if type(s) ~= "string" then print("请输入字符串,拜托!!!") return nil end local s = s:gsub("%d", "*") return s end print(numberToStar("Lua123Code"))
-- 9. 编写函数,将字符串中的中文数字(一二三四)转为阿拉伯数字(1234)。
local Chinesetbl = { "一", "二", "三", "四", "五", "六", "七", "八", "九", [0] = "零"} local function matchChineseToNumber(s) if type(s) ~= "string" then print("请输入字符串,拜托!!!") return nil end for i, v in pairs(Chinesetbl) do s = s:gsub(v, i) end return s end print(matchChineseToNumber("一二零三四"))
-- 10. 实现一个函数,反转字符串中每个单词的位置,但保持单词内部字母顺序不变。
local function reversedStr(s) if type(s) ~= "string" then print("请输入字符串,拜托!!!") return nil end local resultTable = {} local mod = "%w+" for part in s:gmatch(mod) do table.insert(resultTable, part) end local resultTableCount = #resultTable local middleNumber = math.floor(resultTableCount / 2) for i = 1, middleNumber do resultTable[i], resultTable[#resultTable + 1 - i] = resultTable[#resultTable + 1 - i], resultTable[i] end return table.concat(resultTable, " ") end print(reversedStr("halo")) print(reversedStr("Lua is fun"))