如何清除无效电子邮件地址中的文件

如何解决如何清除无效电子邮件地址中的文件

| 我正在寻找一个脚本或一些将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 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?