现在,当然,我可以编写正则表达式来处理这两种情况,例如regexp.Compile("[a-zA-Z]")
,但是我的正则表达式是由用户给出的字符串构造的:
reg, err := regexp.Compile(strings.Replace(s.Name, " ", "[ \\._-]", -1))
s.Name
名字在哪里。这可能类似于“西北偏北”。现在,对我来说最明显的解决方案是遍历每个字符s.Name
并为每个字母写 '[nN]':
for i := 0; i < len(s.Name); i++ {
if s.Name[i] == " " {
fmt.Fprintf(str, "%s[ \\._-]", str);
} else {
fmt.Fprintf(str, "%s[%s%s]", str, strings.ToLower(s.Name[i]), strings.ToUpper(s.Name[i]))
}
}
但我觉得这是一个相当不优雅的解决方案。速度并不是真正的问题,但我需要知道是否有其他方法。