{"id":3961,"date":"2018-06-08T20:40:20","date_gmt":"2018-06-08T12:40:20","guid":{"rendered":"https:\/\/ixyzero.com\/blog\/?p=3961"},"modified":"2018-06-08T20:40:20","modified_gmt":"2018-06-08T12:40:20","slug":"html%e4%b8%ad%e7%89%b9%e5%ae%9atable%e6%a0%b7%e5%bc%8f%e7%9a%84%e5%88%86%e6%9e%90%e5%92%8c%e7%94%9f%e6%88%90","status":"publish","type":"post","link":"https:\/\/ixyzero.com\/blog\/archives\/3961.html","title":{"rendered":"HTML\u4e2d\u7279\u5b9atable\u6837\u5f0f\u7684\u5206\u6790\u548c\u751f\u6210"},"content":{"rendered":"<p>=Start=<\/p>\n<h4 id=\"id-\u6a21\u677f-\u7f18\u7531\uff1a\">\u7f18\u7531\uff1a<\/h4>\n<p>\u5728\u5904\u7406\u4e00\u4e2a\u9700\u6c42\u7684\u65f6\u5019\u78b0\u5230\u7684\u95ee\u9898\uff0c\u89c9\u5f97\u4ee5\u540e\u53ef\u80fd\u4f1a\u7528\u5230\u8fd9\u4e2a\u6216\u8005\u7c7b\u4f3c\u7684\u77e5\u8bc6\u70b9\uff0c\u6240\u4ee5\u5728\u6b64\u8bb0\u5f55\u4e00\u4e0b\uff0c\u65b9\u4fbf\u4ee5\u540e\u53c2\u8003\u3002<\/p>\n<h4 id=\"id-\u6a21\u677f-\u6b63\u6587\uff1a\">\u6b63\u6587\uff1a<\/h4>\n<h5 id=\"id-\u6a21\u677f-\u53c2\u8003\u89e3\u7b54\uff1a\">\u53c2\u8003\u89e3\u7b54\uff1a<\/h5>\n<p>\u5e38\u89c4\u7684\u5355\u884cHTML\u8868\u683c\u751f\u6210\u6bd4\u8f83\u7b80\u5355\uff0c\u53ef\u4ee5\u53c2\u8003\u4e00\u4e0b\u4e4b\u524d\u8bb0\u5f55\u7684\u6587\u7ae0\u300a<a href=\"https:\/\/ixyzero.com\/blog\/archives\/3701.html\" target=\"_blank\" rel=\"noopener\">\u5982\u4f55\u8ba9\u90ae\u4ef6\u4e2d\u5c55\u793a\u7684table\u8868\u683c\u66f4\u987a\u773c\uff1f<\/a>\u300b\uff0c\u5927\u81f4\u6548\u679c\u662f\uff1a<\/p>\n<p><img loading=\"lazy\" decoding=\"async\" class=\"alignnone  wp-image-3965\" src=\"https:\/\/ixyzero.com\/blog\/wp-content\/uploads\/2018\/06\/normal_html_table.png\" alt=\"\" width=\"273\" height=\"98\" srcset=\"https:\/\/ixyzero.com\/wp-content\/uploads\/2018\/06\/normal_html_table.png 462w, https:\/\/ixyzero.com\/wp-content\/uploads\/2018\/06\/normal_html_table-300x108.png 300w\" sizes=\"auto, (max-width: 273px) 100vw, 273px\" \/><\/p>\n<p>\u7528Python\u6216\u662f\u5176\u5b83\u7f16\u7a0b\u8bed\u8a00\u7684\u4ee3\u7801\u5b9e\u73b0\u65b9\u5f0f\u5c31\u662f\u2014\u2014\u5148\u521b\u5efa\u4e00\u4e2alist\uff0c\u7136\u540e\u5faa\u73af\u7ec4\u88c5\u6bcf\u4e00\u5217\u7684\u5185\u5bb9\u4f5c\u4e3a\u5143\u7d20append\u5230list\u91cc\u9762\uff0c\u7136\u540estr.join\u628alist\u7684\u5185\u5bb9\u8fde\u63a5\u8d77\u6765\u4f5c\u4e3a\u5185\u5bb9\u5373\u53ef\u3002<\/p>\n<p>\u4f46\u662f\uff0c\u73b0\u5728\u6709\u4e2a\u9700\u6c42\u5c31\u662f\u90e8\u5206\u884c\u76f8\u540c\u7684\u5185\u5bb9\u8981\u5408\u5e76\u5c55\u793a\uff0c\u6bd4\u5982\uff1a<\/p>\n<p><img loading=\"lazy\" decoding=\"async\" class=\"alignnone  wp-image-3964\" src=\"https:\/\/ixyzero.com\/blog\/wp-content\/uploads\/2018\/06\/normal_html_table_rowspan.png\" alt=\"\" width=\"199\" height=\"157\" srcset=\"https:\/\/ixyzero.com\/wp-content\/uploads\/2018\/06\/normal_html_table_rowspan.png 338w, https:\/\/ixyzero.com\/wp-content\/uploads\/2018\/06\/normal_html_table_rowspan-300x236.png 300w\" sizes=\"auto, (max-width: 199px) 100vw, 199px\" \/><\/p>\n<p>\u8fd9\u5c31\u4e0d\u592a\u597d\u5904\u7406\u4e86\uff0c\u4f46\u4e5f\u4e0d\u662f\u5b8c\u5168\u5904\u7406\u4e0d\u4e86\uff0c\u53ea\u4e0d\u8fc7\u76f8\u5bf9\u4e8e\u4e4b\u524d\u7684for\u5faa\u73af\u6765\u8bf4\u8fd8\u662f\u8981\u590d\u6742\u4e00\u4e9b\uff0c\u9700\u8981\uff1a<\/p>\n<ol>\n<li>\u5148\u6392\u5e8f\uff0c\u5c06\u76f8\u540c\u7684item\u5206\u7ec4\uff1b<\/li>\n<li>\u518d\u6839\u636e\u5206\u7ec4\u7684\u5927\u5c0f\u6765\u8bbe\u7f6e\u7ec4\u5185\u7b2c\u4e00\u884c\u7684rowspan\u5c5e\u6027\u503c\uff1b<\/li>\n<li>\u7ec4\u5185\u5176\u5b83\u884c\u7684td\u4e2a\u6570\u8981\u914c\u60c5\u51cf\u5c11\uff0c\u5426\u5219\u4f1a\u51fa\u73b0\u8d8a\u754c\u7684\u60c5\u51b5\u3002<\/li>\n<\/ol>\n<p>\u4e0b\u9762\u5148\u653e\u6d4b\u8bd5\u8fc7\u7a0b\u4e2d\u4ea7\u751f\u7684\u5404\u79cdtable\u6837\u5f0f\u5bf9\u6bd4\uff1a<\/p>\n<p><img loading=\"lazy\" decoding=\"async\" class=\"alignnone  wp-image-3963\" src=\"https:\/\/ixyzero.com\/blog\/wp-content\/uploads\/2018\/06\/html_table_rowspan_effect.png\" alt=\"\" width=\"306\" height=\"238\" srcset=\"https:\/\/ixyzero.com\/wp-content\/uploads\/2018\/06\/html_table_rowspan_effect.png 720w, https:\/\/ixyzero.com\/wp-content\/uploads\/2018\/06\/html_table_rowspan_effect-300x233.png 300w\" sizes=\"auto, (max-width: 306px) 100vw, 306px\" \/><\/p>\n<p>\u518d\u653e\u5bf9\u5e94\u7684HTML\u6e90\u6587\u4ef6\u6765\u5206\u6790\u539f\u56e0\uff1a<\/p>\n<p><img loading=\"lazy\" decoding=\"async\" class=\"alignnone size-full wp-image-3962\" src=\"https:\/\/ixyzero.com\/blog\/wp-content\/uploads\/2018\/06\/html_table_rowspan.png\" alt=\"\" width=\"2140\" height=\"1476\" srcset=\"https:\/\/ixyzero.com\/wp-content\/uploads\/2018\/06\/html_table_rowspan.png 2140w, https:\/\/ixyzero.com\/wp-content\/uploads\/2018\/06\/html_table_rowspan-300x207.png 300w, https:\/\/ixyzero.com\/wp-content\/uploads\/2018\/06\/html_table_rowspan-768x530.png 768w, https:\/\/ixyzero.com\/wp-content\/uploads\/2018\/06\/html_table_rowspan-1024x706.png 1024w\" sizes=\"auto, (max-width: 2140px) 100vw, 2140px\" \/><\/p>\n<p>\u6700\u540e\u518d\u653e\u76f8\u5e94\u7684Python\u4ee3\u7801\uff1a<\/p>\n<pre class=\"lang:default decode:true \">#!\/usr\/bin\/env python\r\n# coding=utf-8\r\n\r\ntable_style = \"\"\"\r\n&lt;style&gt;\r\ntable {\r\n    border-collapse: collapse;\r\n}\r\ntable, td, th {\r\n    border: 1px solid black;\r\n    text-align: center;\r\n}\r\nth {\r\n    background-color: #e0e0e0;\r\n    color: black;\r\n}\r\ntr:hover {background-color: #f5f5f5;}\r\ntr:nth-child(even) {background-color: #f2f2f2;}\r\n&lt;\/style&gt;\r\n\"\"\"\r\n\r\n\r\nresult_list = [\r\n    '2018-05-02 11:27:43,operate_user1,target_user1',\r\n    '2018-05-02 11:47:33,operate_user1,target_user2',\r\n    '2018-05-02 11:53:06,operate_user2,target_user2',\r\n    '2018-05-03 17:23:28,operate_user3,target_user3',\r\n]\r\n\r\nresult = {\r\n    'operate_user1': [\r\n        '2018-05-02 11:27:43,operate_user1,target_user1',\r\n        '2018-05-02 11:47:33,operate_user1,target_user2',\r\n    ],\r\n    'operate_user2': [\r\n        '2018-05-02 11:53:06,operate_user2,target_user2',\r\n    ],\r\n    'operate_user3': [\r\n        '2018-05-03 17:23:28,operate_user3,target_user3',\r\n    ],\r\n}\r\n\r\n# '{0},{1},{2}'.format(_datetime, operate_name, target_name)\r\n\r\nresult_content = [ table_style ]\r\nresult_content.append('&lt;div&gt;\\n&lt;table&gt;\\n&lt;tr&gt;&lt;th&gt;\u65e5\u671f&lt;\/th&gt;&lt;th&gt;\u65f6\u95f4&lt;\/th&gt;&lt;th&gt;\u64cd\u4f5c\u4eba&lt;\/th&gt;&lt;th&gt;\u64cd\u4f5c\u7c7b\u578b&lt;\/th&gt;&lt;th&gt;\u88ab\u64cd\u4f5c\u5bf9\u8c61&lt;\/th&gt;&lt;th&gt;\u64cd\u4f5c\u5b57\u6bb5&lt;\/th&gt;&lt;th&gt;\u603b\u64cd\u4f5c\u6b21\u6570&lt;\/th&gt;&lt;\/tr&gt;\\n')\r\nfor k, v in sorted(result.items()):\r\n    if len(v) &gt; 1:\r\n        _date, _time, _operate, _target = v[0].replace(' ', ',').split(',')\r\n        result_content.append('&lt;tr&gt;&lt;td&gt;{0}&lt;\/td&gt;&lt;td&gt;{1}&lt;\/td&gt;&lt;td rowspan=\"{4}\"&gt;{2}&lt;\/td&gt;&lt;td rowspan=\"{4}\"&gt;\u67e5\u8be2&lt;\/td&gt;&lt;td&gt;{3}&lt;\/td&gt;&lt;td&gt;\u5b57\u6bb5A&lt;\/td&gt;&lt;td rowspan=\"{4}\"&gt;{4}&lt;\/td&gt;&lt;\/tr&gt;\\n'.format(_date, _time, _operate, _target, len(v)))\r\n        for item in v[1:]:\r\n            _date, _time, _operate, _target = item.replace(' ', ',').split(',')\r\n            # result_content.append('&lt;tr&gt;&lt;td&gt;{0}&lt;\/td&gt;&lt;td&gt;{1}&lt;\/td&gt;&lt;td&gt;{2}&lt;\/td&gt;&lt;td&gt;\u67e5\u8be2&lt;\/td&gt;&lt;td&gt;{3}&lt;\/td&gt;&lt;td&gt;\u5b57\u6bb5A&lt;\/td&gt;&lt;td&gt;{4}&lt;\/td&gt;&lt;\/tr&gt;\\n'.format(_date, _time, _operate, _target, len(v)))\r\n            result_content.append('&lt;tr&gt;&lt;td&gt;{0}&lt;\/td&gt;&lt;td&gt;{1}&lt;\/td&gt;&lt;td&gt;{3}&lt;\/td&gt;&lt;td&gt;\u5b57\u6bb5A&lt;\/td&gt;&lt;\/tr&gt;\\n'.format(_date, _time, _operate, _target))\r\n    else:\r\n        _date, _time, _operate, _target = v[0].replace(' ', ',').split(',')\r\n        result_content.append('&lt;tr&gt;&lt;td&gt;{0}&lt;\/td&gt;&lt;td&gt;{1}&lt;\/td&gt;&lt;td&gt;{2}&lt;\/td&gt;&lt;td&gt;\u67e5\u8be2&lt;\/td&gt;&lt;td&gt;{3}&lt;\/td&gt;&lt;td&gt;\u5b57\u6bb5A&lt;\/td&gt;&lt;td&gt;{4}&lt;\/td&gt;&lt;\/tr&gt;\\n'.format(_date, _time, _operate, _target, 1))\r\nresult_content.append('&lt;\/table&gt;\\n&lt;\/div&gt;')\r\n\r\nwith open('display.html', 'w') as fp:\r\n    fp.write(''.join(result_content))<\/pre>\n<p>&nbsp;<\/p>\n<h5 id=\"id-\u6a21\u677f-\u53c2\u8003\u94fe\u63a5\uff1a\">\u53c2\u8003\u94fe\u63a5\uff1a<\/h5>\n<ul>\n<li><a href=\"http:\/\/www.w3school.com.cn\/tags\/tag_table.asp\">HTML &lt;table&gt; \u6807\u7b7e<\/a><\/li>\n<li><a href=\"http:\/\/www.w3school.com.cn\/tiy\/t.asp?f=html_table_span\">\u8de8\u884c\u6216\u8de8\u5217\u7684\u8868\u683c\u5355\u5143\u683c<\/a><\/li>\n<li><a href=\"http:\/\/www.w3school.com.cn\/tags\/att_td_rowspan.asp\">HTML &lt;td&gt; \u6807\u7b7e\u7684 rowspan \u5c5e\u6027<\/a><\/li>\n<\/ul>\n<p>=END=<\/p>\n","protected":false},"excerpt":{"rendered":"<p>=Start= \u7f18\u7531\uff1a \u5728\u5904\u7406\u4e00\u4e2a\u9700\u6c42\u7684\u65f6\u5019\u78b0\u5230\u7684\u95ee\u9898\uff0c\u89c9\u5f97\u4ee5\u540e\u53ef\u80fd\u4f1a\u7528\u5230\u8fd9\u4e2a\u6216\u8005\u7c7b\u4f3c\u7684\u77e5\u8bc6\u70b9\uff0c\u6240\u4ee5\u5728\u6b64\u8bb0\u5f55\u4e00 [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[23,7],"tags":[34,8,1146,1145],"class_list":["post-3961","post","type-post","status-publish","format-standard","hentry","category-knowledgebase-2","category-programing","tag-html","tag-python","tag-rowspan","tag-table"],"views":3061,"_links":{"self":[{"href":"https:\/\/ixyzero.com\/blog\/wp-json\/wp\/v2\/posts\/3961","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/ixyzero.com\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/ixyzero.com\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/ixyzero.com\/blog\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/ixyzero.com\/blog\/wp-json\/wp\/v2\/comments?post=3961"}],"version-history":[{"count":2,"href":"https:\/\/ixyzero.com\/blog\/wp-json\/wp\/v2\/posts\/3961\/revisions"}],"predecessor-version":[{"id":3972,"href":"https:\/\/ixyzero.com\/blog\/wp-json\/wp\/v2\/posts\/3961\/revisions\/3972"}],"wp:attachment":[{"href":"https:\/\/ixyzero.com\/blog\/wp-json\/wp\/v2\/media?parent=3961"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/ixyzero.com\/blog\/wp-json\/wp\/v2\/categories?post=3961"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/ixyzero.com\/blog\/wp-json\/wp\/v2\/tags?post=3961"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}