如何解决如何清除无效电子邮件地址中的文件
| 我正在寻找一个脚本或一些将csv文件作为输入的文件。 它将逐行解析文件,并检查当前行是否包含有效的电子邮件(例如:user@domain.ext) 我认为这一定已经存在。 带有一些javascript / jquery的本地html文件将是完美的。 我需要它来检查带有手动输入的电子邮件且没有验证的列表。 谢谢 米歇尔解决方法
您将无法使用javascript读取或写入本地文件,我是用ruby编写的。如果代码对您没有用,则正则表达式可能有用。
#!/usr/bin/ruby
File.open(\"somefile.csv\").each{ |line|
if line =~ /\\w+@[a-zA-Z_]+?\\.[a-zA-Z]{2,6}/
puts \"Good email!\"
else
puts \"FAIL\"
end
}
,1)警告,验证电子邮件地址非常困难。实际上,不可能做到完美。这是表达复杂度,覆盖范围和准确性(误报)之间的折衷方案。请参阅SO上与验证电子邮件地址有关的无数其他问题,也请参见此处:http://www.regular-expressions.info/email.html
2)您有一个平面文件(.csv)。您无法使用javascript阅读内容并无法在浏览器中进行处理。您需要查看其他语言。 Perl和Java随机提及两种语言都具有良好的正则表达式支持。
,由于您一直在寻找Javascript解决方案,因此假设您有一些包含csv数据的文件,这是一些简单的JS:
<pre id=\"csv\">
a,b,567@noe.invalid!tld
1,2,me@example.net
4,5,so@ex.com
</pre>
这是您可能要替换分隔符,使用的换行符或用于检查地址的正则表达式的脚本。根据您的验证要求,在此处查找其他正则表达式:在JavaScript中验证电子邮件地址?
var separator = \',\',linebreak = \'\\n\',regex = /^([a-zA-Z0-9_\\.\\-])+\\@(([a-zA-Z0-9\\-])+\\.)+([a-zA-Z0-9]{2,4})+$/,csv = document.getElementById(\'csv\'),lines = csv.innerHTML.split(linebreak),fields,i;
for(i = 0; i < lines.length; i++)
{
fields = lines[i].split(separator);
if (regex.test(fields[mailColumn]))
{
document.write(fields[mailColumn] + \' is valid<br/>\');
}
}
,您好,谢谢您的回答。
我最终设法用本地html文件和javascript做到了这一点。
方法如下:
拥有本地网络服务器(例如xampp)
创建一个HTML文件,该文件将使用jquery(例如)在AJAX中加载csv文件
将\\ n(换行符)上的已加载文件拆分为一个数组
根据需要处理每个数组元素(再次在\“; \”等处分割)
填写两个textarea字段:一个使用有效的电子邮件地址,另一个使用无效的电子邮件地址
手动修复或删除无效文本区域中的地址
将有效文本区域复制/粘贴到新的干净文件中
为了使其正常工作,我将csv文件放在html文件旁边,然后使用\“ input type = file \”加载它
和瞧:-)
原始代码:
<!DOCTYPE html>
<html>
<head>
<meta http-equiv=\"Content-Type\" content=\"text/html; charset=iso-8859-1\" />
<title>Validation email</title>
<script src=\"jquery.js\"></script>
<script>
function isValidEmailAddress(emailAddress) {
var pattern = new RegExp(/^((\"[\\w-\\s]+\")|([\\w-]+(?:\\.[\\w-]+)*)|(\"[\\w-\\s]+\")([\\w-]+(?:\\.[\\w-]+)*))(@((?:[\\w-]+\\.)*\\w[\\w-]{0,66})\\.([a-z]{2,6}(?:\\.[a-z]{2})?)$)|(@\\[?((25[0-5]\\.|2[0-4][0-9]\\.|1[0-9]{2}\\.|[0-9]{1,2}\\.))((25[0-5]|2[0-4][0-9]|1[0-9]{2}|[0-9]{1,2})\\.){2}(25[0-5]|2[0-4][0-9]|1[0-9]{2}|[0-9]{1,2})\\]?$)/i);
return pattern.test(emailAddress);
};
function no_accent (my_string) {
var new_string = \"\";
var pattern_accent = new Array(\'À\',\'Á\',\'Â\',\'Ã\',\'Ä\',\'Å\',\'Æ\',\'Ç\',\'È\',\'É\',\'Ê\',\'Ë\',\'Ì\',\'Í\',\'Î\',\'Ï\',\'Ð\',\'Ñ\',\'Ò\',\'Ó\',\'Ô\',\'Õ\',\'Ö\',\'Ø\',\'Ù\',\'Ú\',\'Û\',\'Ü\',\'Ý\',\'Þ\',\'ß\',\'à\',\'á\',\'â\',\'ã\',\'ä\',\'å\',\'æ\',\'ç\',\'è\',\'é\',\'ê\',\'ë\',\'ì\',\'í\',\'î\',\'ï\',\'ð\',\'ñ\',\'ò\',\'ó\',\'ô\',\'õ\',\'ö\',\'ø\',\'ù\',\'ú\',\'û\',\'ü\',\'ý\',\'þ\',\'ÿ\');
var pattern_replace_accent = new Array(\'A\',\'A\',\'C\',\'E\',\'I\',\'D\',\'N\',\'O\',\'0\',\'U\',\'Y\',\'b\',\'s\',\'a\',\'c\',\'e\',\'i\',\'d\',\'n\',\'o\',\'u\',\'y\',\'y\');
if (my_string && my_string!= \"\") {
new_string = preg_replace (pattern_accent,pattern_replace_accent,my_string);
}
return new_string;
}
$(document).ready(function() {
$(\'#checkMail\').click(function() {
$(\'#invalid\').val(\'\');
$(\'#valid\').val(\'\');
$.ajax({
type: \"GET\",url: $(\'#fileName\').val(),dataType: \"text\",cache:false,success: function(text) {
alert(\"Start process\");
var reg=new RegExp(\"\\r\\n\",\"g\");
var monTab = text.split(reg);
for (cpt=0;cpt<monTab.length;cpt++){
//do some custom check here if needed
if (isValidEmailAddress(monTab[cpt])){
//add to valid textarea
document.getElementById(\'valid\').value += monTab[cpt] + \"\\r\\n\";
} else {
//add to invalid textarea
document.getElementById(\'invalid\').value += monTab[cpt] + \"\\r\\n\";
}
}
alert(\"Process over!\");
}
});//close $.ajax
});
});
</script>
</head>
<body>
<input type=\"file\" name=\"myfile\" size=\"50\" id=\"fileName\"> (put csv file next to this html file)<br/>
<input type=\"button\" value=\"Process\" id=\"checkMail\">
<br/>
Invalid adresses : <br/>
<textarea id=\"invalid\" cols=\"80\" rows=\"20\"></textarea>
<br/>
Valid adresses : <br/>
<textarea id=\"valid\" cols=\"80\" rows=\"20\"></textarea>
</body>
</html>
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。