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

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

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

相关推荐


依赖报错 idea导入项目后依赖报错,解决方案:https://blog.csdn.net/weixin_42420249/article/details/81191861 依赖版本报错:更换其他版本 无法下载依赖可参考:https://blog.csdn.net/weixin_42628809/a
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下 2021-12-03 13:33:33.927 ERROR 7228 [ main] o.s.b.d.LoggingFailureAnalysisReporter : *************************** APPL
错误1:gradle项目控制台输出为乱码 # 解决方案:https://blog.csdn.net/weixin_43501566/article/details/112482302 # 在gradle-wrapper.properties 添加以下内容 org.gradle.jvmargs=-Df
错误还原:在查询的过程中,传入的workType为0时,该条件不起作用 &lt;select id=&quot;xxx&quot;&gt; SELECT di.id, di.name, di.work_type, di.updated... &lt;where&gt; &lt;if test=&qu
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct redisServer’没有名为‘server_cpulist’的成员 redisSetCpuAffinity(server.server_cpulist); ^ server.c: 在函数‘hasActiveC
解决方案1 1、改项目中.idea/workspace.xml配置文件,增加dynamic.classpath参数 2、搜索PropertiesComponent,添加如下 &lt;property name=&quot;dynamic.classpath&quot; value=&quot;tru
删除根组件app.vue中的默认代码后报错:Module Error (from ./node_modules/eslint-loader/index.js): 解决方案:关闭ESlint代码检测,在项目根目录创建vue.config.js,在文件中添加 module.exports = { lin
查看spark默认的python版本 [root@master day27]# pyspark /home/software/spark-2.3.4-bin-hadoop2.7/conf/spark-env.sh: line 2: /usr/local/hadoop/bin/hadoop: No s
使用本地python环境可以成功执行 import pandas as pd import matplotlib.pyplot as plt # 设置字体 plt.rcParams[&#39;font.sans-serif&#39;] = [&#39;SimHei&#39;] # 能正确显示负号 p
错误1:Request method ‘DELETE‘ not supported 错误还原:controller层有一个接口,访问该接口时报错:Request method ‘DELETE‘ not supported 错误原因:没有接收到前端传入的参数,修改为如下 参考 错误2:cannot r
错误1:启动docker镜像时报错:Error response from daemon: driver failed programming external connectivity on endpoint quirky_allen 解决方法:重启docker -&gt; systemctl r
错误1:private field ‘xxx‘ is never assigned 按Altʾnter快捷键,选择第2项 参考:https://blog.csdn.net/shi_hong_fei_hei/article/details/88814070 错误2:启动时报错,不能找到主启动类 #
报错如下,通过源不能下载,最后警告pip需升级版本 Requirement already satisfied: pip in c:\users\ychen\appdata\local\programs\python\python310\lib\site-packages (22.0.4) Coll
错误1:maven打包报错 错误还原:使用maven打包项目时报错如下 [ERROR] Failed to execute goal org.apache.maven.plugins:maven-resources-plugin:3.2.0:resources (default-resources)
错误1:服务调用时报错 服务消费者模块assess通过openFeign调用服务提供者模块hires 如下为服务提供者模块hires的控制层接口 @RestController @RequestMapping(&quot;/hires&quot;) public class FeignControl
错误1:运行项目后报如下错误 解决方案 报错2:Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.8.1:compile (default-compile) on project sb 解决方案:在pom.
参考 错误原因 过滤器或拦截器在生效时,redisTemplate还没有注入 解决方案:在注入容器时就生效 @Component //项目运行时就注入Spring容器 public class RedisBean { @Resource private RedisTemplate&lt;String
使用vite构建项目报错 C:\Users\ychen\work&gt;npm init @vitejs/app @vitejs/create-app is deprecated, use npm init vite instead C:\Users\ychen\AppData\Local\npm-