我正在尝试在处理值之前清理包含邮政编码的数据列。数据包含各种疯狂的格式或输入,如下所示,并且是CHAR数据类型:
12345 12.345 1234-5678 12345 6789 123456789 12345-6789 。 [空白]
我想删除所有特殊字符,并尝试了以下代码,但是我的脚本在多次逻辑迭代后失败。当我说失败时,假设sOriginalZip ='。',但是即使我替换了所有特殊字符,控制字符和空格字符,它也会通过空字符串检查和nil检查,好像它不为空。所以我的输出看起来像这样: “ 2 sZip5 =”
代码:
nNull = nil
sZip5 = string.gsub(sOriginalZip,"%p","")
sZip5 = string.gsub(sZip5,"%c","")
sZip5 = string.gsub(sZip5,"%s","")
print("sZip5 = " .. sZip5)
if sZip5 ~= sBlank or tonumber(sZip5) ~= nNull then
print(" 2 sZip5 = " .. sZip5)
else
print("3 sZip5 = " .. sZip5)
end
答案 0 :(得分:0)
我认为可以采取不同的方法,以下方法应该可行:
sZip5 = string.gsub(sOriginalZip, '.', function(d) return tonumber(d) and d or '' end)
它返回数字字符串,空白值或nil
答案 1 :(得分:0)
谢谢!我最终结合使用csarr和Egor的建议来获得此信息:
sZip5 = string.gsub(sOriginalZip,"%W",function(d)return tonumber(d) and d or "" end)
看起来它正在正确评估。再次感谢!