• 用HTML + javaScript快速完成excel表格信息除重并合并


    今天突然接到一个工作,要把两个存储在.xls的主体信息表,除重后合并成一个主体信息表,并且补充主体类型和所在县区这两列信息。
    完成这项工作的方法有很多,如果信息表中的信息量不大的话,手工处理一下也行,如果信息量大的话,还是由电脑来处理比较好,比如用vba写代码来合并,不过我更喜欢用JavaScript来完成。


    一、思路

    (一)界面设计


    用HTML设计页面,放置两个textarea

    其中一个textarea(ID=ta1)用来存放要处理的原始企业信息

    另一个textarea(ID=ta2)用来存放处理好的企业信息。

    代码如下:

    1. html>
    2. <html>
    3. <head>
    4. <title>文本筛选合并title>
    5. <style type="text/css">
    6. * {
    7. padding: 0px;
    8. margin: 0px;
    9. }
    10. html,
    11. body {
    12. overflow-y: hidden;
    13. }
    14. .ta_div {
    15. border: 1px solid #CCCCCC;
    16. overflow: auto;
    17. position: relative;
    18. }
    19. .ta_div textarea {
    20. resize: none;
    21. background: none repeat scroll 0 0 transparent;
    22. border: 1 solid black;
    23. width: 99%;
    24. height: 200px;
    25. overflow-y: scroll;
    26. //position: absolute;
    27. left: 0px;
    28. top: 0px;
    29. z-index: 2;
    30. font-size: 18px;
    31. white-space: pre-wrap;
    32. word-wrap: break-word;
    33. word-break: break-all;
    34. }
    35. p {text-align:center; color:purple}
    36. style>
    37. head>
    38. <body>
    39. <table style="width:100%; borderspacing:0; cellpadding:0;">
    40. <tr>
    41. <td style="width:49%">
    42. <div class="ta_div">
    43. <p>原始数据p>
    44. <textarea id="ta1" onscroll="ta1_scroll()" oninput="t()" onpropertychange="t()">请输入原始数据textarea>
    45. div>
    46. td>
    47. <td style="width:49%">
    48. <div class="ta_div">
    49. <p>整理后的数据p>
    50. <textarea id="ta2" onscroll="ta2_scroll()" oninput="textchange()" onpropertychange="textchange()">合并后的数据textarea>
    51. div>
    52. td>
    53. tr>
    54. table>
    55. body>
    56. html>


    (二)信息处理

    1.从ta1读取原始主体名称信息

    2.对信息进行清洗

    1. 用正则表达式删除信息首尾空格
    2. 从excel复制过来信息中有时包含双引号要删除
    3. 对于多个连续的换行符(\n\n)要换成一个换行符(\n)
    1. var v = ta1.value.trim();//去除首尾空格
    2. v = v.replace(/\"/g, ""); //去除半角双引号
    3. v = v.replace(/\n[\s]*\n/g, "\n"); //去除多余的\n,避免空行

     

    3.如果信息长度为0,提示输入信息并结束处理 

    4.用split方法将其按换行符(\n)转换为数组a

    	var a = v.split('\n');
    

     5.使用 es6 的 Set 和 Array.from 方法从数组a 生成去重后的数组b

     

    	var b = Array.from(new Set([...a]));
    

    6.对数组b中的信息增加类型和所在县区信息

    1. 增加类型信息,主体类型分为三类:合作社、家庭农场、公司,搜索数组b中主体名称,如果包含合作社、家庭农场,就为其增加相应类型,否则增加"公司"
    2. 增加县区信息搜索数组b中企业名称,如果包含县区名称,就为其增加相应的县区信息,否则增加"*未知"

     

    1. function addType(n)
    2. {
    3. //补充类型
    4. var a = ['合作社','家庭农场','公司'];
    5. var j;
    6. for (j=0; j < a.length-1; j++ )
    7. {
    8. if (-1 != n.indexOf(a[j]))
    9. {
    10. break;
    11. }
    12. }
    13. return '\t' + a[j];
    14. } //addType()
    15. function addArea(n)
    16. {
    17. //补充所在县(区)
    18. var a = ['金城江','宜州','罗城','环江','南丹','天峨','东兰','巴马','凤山','都安','大化','*未知'];
    19. var j;
    20. for (j=0; j < a.length-1; j++ )
    21. {
    22. if (-1 != n.indexOf(a[j]))
    23. {
    24. break;
    25. }
    26. }
    27. return '\t' + a[j];
    28. } //addArea()
    29. function addData(a)
    30. {
    31. //追加信息
    32. for (var i=0; i < a.length; i++)
    33. {
    34. a[i] += addType(a[i]); //补充类型
    35. a[i] += addArea(a[i]); //补充所在县(区)
    36. }
    37. } //addData(a)


    7.利用join方法将数组b用换行符(\n)连接起来,存储到ta2中。

    	document.getElementById("ta2").value = b.join('\n');
    

    二、运行效果

    三、完整的代码

     

    1. <html>
    2. <head>
    3. <title>文本筛选合并title>
    4. <style type="text/css">
    5. * {
    6. padding: 0px;
    7. margin: 0px;
    8. }
    9. html,
    10. body {
    11. overflow-y: hidden;
    12. }
    13. .ta_div {
    14. border: 1px solid #CCCCCC;
    15. overflow: auto;
    16. position: relative;
    17. }
    18. .ta_div textarea {
    19. resize: none;
    20. background: none repeat scroll 0 0 transparent;
    21. border: 0 none;
    22. width: 100%;
    23. height: 200px;
    24. overflow-y: scroll;
    25. //position: absolute;
    26. left: 0px;
    27. top: 0px;
    28. z-index: 2;
    29. font-size: 18px;
    30. white-space: pre-wrap;
    31. word-wrap: break-word;
    32. word-break: break-all;
    33. }
    34. p {text-align:center; color:purple}
    35. style>
    36. head>
    37. <body>
    38. <table style="width:100%">
    39. <tr>
    40. <td style="width:50%">
    41. <div class="ta_div">
    42. <p>原始数据p>
    43. <textarea id="ta1" onscroll="ta1_scroll()" oninput="t()" onpropertychange="t()">请输入原始数据textarea>
    44. div>
    45. td>
    46. <td style="width:50%">
    47. <div class="ta_div">
    48. <p>整理后的数据p>
    49. <textarea id="ta2" onscroll="ta2_scroll()" oninput="textchange()" onpropertychange="textchange()">合并后的数据textarea>
    50. div>
    51. td>
    52. tr>
    53. table>
    54. <script>
    55. String.prototype.trim = function()
    56. {
    57. //功能:去除首尾空格
    58. return this.replace(/(^\s*)|(\s*$)/g, "");
    59. /*var t = this.replace(/(^\s*)|(\s*$)/g, "");
    60. return t =t.replace(/(^ *)|( *$)/g, ""); */
    61. }
    62. var ta1 = document.getElementById("ta1");
    63. function t()
    64. {
    65. var v = ta1.value.trim();
    66. if ('' == v)
    67. {
    68. alert('请先输入原始数据');
    69. }
    70. v = v.replacereplace(/\"/g, ""); //去除半角双引号
    71. //v = v.replace('','\n'
    72. a = v.split('\n');
    73. b = Array.from(new Set([...a]));
    74. document.getElementById("ta2").value = b.join('\n');
    75. }
    76. script>
    77. body>
    78. html>

  • 相关阅读:
    2022年7月最新贴吧防删图制作教学视频
    简易SSM框架转账
    Git学习笔记——超详细
    MySQL - 为什么InnoDB选择B+树索引?Change buffer?
    Linux绝对路径和相对路径
    跨境专线物流都有哪些专线
    文件系统(一):存储介质、原理与架构
    工程实践 穿越CICD那些事
    关于抽象类和抽象方法
    Go的优雅退出
  • 原文地址:https://blog.csdn.net/Purpleendurer/article/details/134252106