{"id":86910,"date":"2021-09-03T23:07:31","date_gmt":"2021-09-03T15:07:31","guid":{"rendered":"http:\/\/www.zhushiyao.com\/?p=86910"},"modified":"2021-09-03T23:08:07","modified_gmt":"2021-09-03T15:08:07","slug":"76125d0117","status":"publish","type":"post","link":"http:\/\/www.zhushiyao.com\/?p=86910","title":{"rendered":"Django\u6570\u636e\u5bfc\u5165\u5bfc\u51fa\u795e\u5668django-import-export\u4f7f\u7528\u6559\u7a0b"},"content":{"rendered":"<div class=\"bpp-post-content\">\n<p style=\"box-sizing: border-box; color: #3e454c; margin-top: 1em; margin-bottom: 1.5em; vertical-align: baseline; word-break: break-word; line-height: 1.5; font-family: Nunito, sans-serif; font-size: 15.4px; text-align: start; white-space: normal; background-color: #ffffff; border: 0px initial initial;\"><span style=\"box-sizing: border-box; vertical-align: baseline; font-variant-numeric: normal; font-variant-east-asian: normal; line-height: 18px; color: #888888; border: 0px initial initial;\">\u987e\u540d\u601d\u4e49\uff0c<span style=\"font-variant-numeric: normal; font-variant-east-asian: normal; line-height: 18px; font-family: Nunito, sans-serif; font-size: 15.4px; text-align: start; background-color: #ffffff;\">django-import-export<\/span>\u662f\u4e00\u4e2a\u7528\u4e8e\u5904\u7406\u5bfc\u5165\u548c\u5bfc\u51fa\u6570\u636e\u7684\u5e93\u3002\u5b83\u652f\u6301\u591a\u79cd\u683c\u5f0f\uff0c\u5305\u62ecxls\u3001csv\u3001json\u3001yaml\u4ee5\u53catablib\u652f\u6301\u7684\u6240\u6709\u5176\u4ed6\u683c\u5f0f\u3002\u5b83\u8fd8\u53ef\u4ee5\u8f7b\u677e\u4e0eDjango\u7ba1\u7406\u540e\u53f0\u96c6\u6210\uff0c\u4f7f\u7528\u8d77\u6765\u975e\u5e38\u65b9\u4fbf\u3002<\/span><\/p>\n<h3 style=\"box-sizing: border-box; color: #3e454c; font-family: Nunito, sans-serif; font-weight: bold; line-height: 1.35; margin-bottom: 1em; font-size: 1em; vertical-align: baseline; word-break: break-word; text-align: start; white-space: normal; background-color: #ffffff; border: 0px initial initial;\"><span style=\"color: #ffa900;\">\u5b89\u88c5\u63d2\u4ef6<\/span><\/h3>\n<p style=\"box-sizing: border-box; color: #3e454c; margin-top: 1em; margin-bottom: 1.5em; vertical-align: baseline; word-break: break-word; line-height: 1.5; font-family: Nunito, sans-serif; font-size: 15.4px; text-align: start; white-space: normal; background-color: #ffffff; border: 0px initial initial;\"><span style=\"color: #888888;\">\u4f7f\u7528PIP\u5b89\u88c5<\/span><\/p>\n<pre style=\"box-sizing: border-box; color: #191919; overflow: auto; font-family: inconsolata, monospace; font-size: 12px; padding: 0.5em 0.5em 0.5em 15px; margin-top: 20px; margin-bottom: 20px; line-height: 1.45; word-break: break-all; overflow-wrap: normal; background: #fafafa; border-width: 0px 0px 0px 1px; border-radius: 0px; vertical-align: baseline; clear: left; letter-spacing: 0.3px; word-spacing: 1px; text-align: start; border-color: initial initial initial #aec8da; border-style: initial initial initial solid;\">pip\u00a0<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">install<\/span>\u00a0django-<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">import<\/span>-<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">export<\/span><\/pre>\n<p style=\"box-sizing: border-box; color: #3e454c; margin-top: 1em; margin-bottom: 1.5em; vertical-align: baseline; word-break: break-word; line-height: 1.5; font-family: Nunito, sans-serif; font-size: 15.4px; text-align: start; white-space: normal; background-color: #ffffff; border: 0px initial initial;\"><span style=\"color: #888888;\">\u66f4\u65b0<\/span><span style=\"color: #d92142;\"><span style=\"box-sizing: border-box; font-weight: bold; vertical-align: baseline; border: 0px initial initial;\">settings.py<\/span>:<\/span><\/p>\n<pre style=\"box-sizing: border-box; color: #191919; overflow: auto; font-family: inconsolata, monospace; font-size: 12px; padding: 0.5em 0.5em 0.5em 15px; margin-top: 20px; margin-bottom: 20px; line-height: 1.45; word-break: break-all; overflow-wrap: normal; background: #fafafa; border-width: 0px 0px 0px 1px; border-radius: 0px; vertical-align: baseline; clear: left; letter-spacing: 0.3px; word-spacing: 1px; text-align: start; border-color: initial initial initial #aec8da; border-style: initial initial initial solid;\"><span style=\"box-sizing: border-box; color: #dd4a68; vertical-align: baseline; border: 0px initial initial;\">INSTALLED_APPS<\/span>\u00a0=\u00a0(\n\u00a0\u00a0\u00a0\u00a0...\n\u00a0\u00a0\u00a0\u00a0<span style=\"box-sizing: border-box; color: #669900; vertical-align: baseline; border: 0px initial initial;\">'import_export'<\/span>,\n)<\/pre>\n<p style=\"box-sizing: border-box; color: #3e454c; margin-top: 1em; margin-bottom: 1.5em; vertical-align: baseline; word-break: break-word; line-height: 1.5; font-family: Nunito, sans-serif; font-size: 15.4px; text-align: start; white-space: normal; background-color: #ffffff; border: 0px initial initial;\"><span style=\"box-sizing: border-box; vertical-align: baseline; font-variant-numeric: normal; font-variant-east-asian: normal; line-height: 18px; color: #888888; border: 0px initial initial;\">\u8fd8\u6709\u4e00\u4e2a\u53ef\u9009\u7684\u914d\u7f6e\uff0c\u6211\u901a\u5e38\u8fd9\u6837\u6dfb\u52a0:<\/span><\/p>\n<pre style=\"box-sizing: border-box; color: #191919; overflow: auto; font-family: inconsolata, monospace; font-size: 12px; padding: 0.5em 0.5em 0.5em 15px; margin-top: 20px; margin-bottom: 20px; line-height: 1.45; word-break: break-all; overflow-wrap: normal; background: #fafafa; border-width: 0px 0px 0px 1px; border-radius: 0px; vertical-align: baseline; clear: left; letter-spacing: 0.3px; word-spacing: 1px; text-align: start; border-color: initial initial initial #aec8da; border-style: initial initial initial solid;\"><span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">IMPORT_EXPORT_USE_TRANSACTIONS<\/span>\u00a0=\u00a0<span style=\"box-sizing: border-box; color: #f5871f; vertical-align: baseline; border: 0px initial initial;\">True<\/span><\/pre>\n<p style=\"box-sizing: border-box; color: #3e454c; margin-top: 1em; margin-bottom: 1.5em; vertical-align: baseline; word-break: break-word; line-height: 1.5; font-family: Nunito, sans-serif; font-size: 15.4px; text-align: start; white-space: normal; background-color: #ffffff; border: 0px initial initial;\"><span style=\"box-sizing: border-box; vertical-align: baseline; font-variant-numeric: normal; font-variant-east-asian: normal; line-height: 18px; color: #888888; border: 0px initial initial;\">\u9ed8\u8ba4\u503c\u4e3aFalse\u3002\u5b83\u786e\u5b9a\u5e93\u662f\u5426\u4f1a\u5728\u6570\u636e\u5bfc\u5165\u4e2d\u4f7f\u7528\u6570\u636e\u5e93\u4e8b\u52a1\uff0c\u4ee5\u786e\u4fdd\u5b89\u5168\u3002<\/span><\/p>\n<h4 style=\"box-sizing: border-box; color: #3e454c; font-family: Nunito, sans-serif; line-height: 1.35; font-size: 18px; vertical-align: baseline; word-break: break-word; white-space: normal; background-color: #ffffff; text-align: left; border: 0px initial initial;\"><span style=\"color: #ffa900;\"><strong><span style=\"font-size: 17px;\">\u7f16\u5199\u8d44\u6e90Resources<\/span><\/strong><\/span><\/h4>\n<p style=\"box-sizing: border-box; color: #3e454c; margin-top: 1em; margin-bottom: 1.5em; vertical-align: baseline; word-break: break-word; line-height: 1.5; font-family: Nunito, sans-serif; font-size: 15.4px; text-align: start; white-space: normal; background-color: #ffffff; border: 0px initial initial;\"><span style=\"box-sizing: border-box; vertical-align: baseline; color: #888888; border: 0px initial initial;\">django-import-export\u5e93\u4f7f\u7528Resource\u7684\u6982\u5ff5\uff0c\u5b83\u7684\u7c7b\u5b9a\u4e49\u975e\u5e38\u7c7b\u4f3c\u4e8eDjango\u5904\u7406\u6a21\u578b\u8868\u5355\u548c\u7ba1\u7406\u7c7b\u7684\u65b9\u5f0f\u3002<\/span><\/p>\n<p style=\"box-sizing: border-box; color: #3e454c; margin-top: 1em; margin-bottom: 1.5em; vertical-align: baseline; word-break: break-word; line-height: 1.5; font-family: Nunito, sans-serif; font-size: 15.4px; text-align: start; white-space: normal; background-color: #ffffff; border: 0px initial initial;\"><span style=\"box-sizing: border-box; vertical-align: baseline; font-variant-numeric: normal; font-variant-east-asian: normal; line-height: 18px; color: #888888; border: 0px initial initial;\">\u5728\u6587\u6863\u4e2d\uff0c\u4f5c\u8005\u5efa\u8bae\u5c06\u4e0e\u8d44\u6e90\u76f8\u5173\u7684\u4ee3\u7801\u653e\u5728admin.py\u6587\u4ef6\u3002\u4f46\u662f\uff0c\u5982\u679c\u5b9e\u73b0\u4e0eDjango admin\u6ca1\u6709\u5173\u7cfb\uff0c\u6211\u901a\u5e38\u66f4\u559c\u6b22\u5728app\u6587\u4ef6\u5939\u91cc\u521b\u5efa\u4e00\u4e2a\u540d\u4e3aresources.py\u3002<\/span><\/p>\n<p style=\"box-sizing: border-box; color: #3e454c; margin-top: 1em; margin-bottom: 1.5em; vertical-align: baseline; word-break: break-word; line-height: 1.5; font-family: Nunito, sans-serif; font-size: 15.4px; text-align: start; white-space: normal; background-color: #ffffff; border: 0px initial initial;\"><span style=\"box-sizing: border-box; color: inherit; font-weight: bold; vertical-align: baseline; border: 0px initial initial;\">models.py<\/span><\/p>\n<section class=\"code-snippet__fix code-snippet__js\">\n<ul class=\"code-snippet__line-index code-snippet__js\">\n<li><\/li>\n<li><\/li>\n<li><\/li>\n<li><\/li>\n<li><\/li>\n<li><\/li>\n<li><\/li>\n<\/ul>\n<pre class=\"code-snippet__js\"><code><span class=\"code-snippet_outer\">from django.db import models<\/span><\/code><code><span class=\"code-snippet_outer\">\n<\/span><\/code><code><span class=\"code-snippet_outer\">class\u00a0Person(models.Model):<\/span><\/code><code><span class=\"code-snippet_outer\">    name\u00a0=\u00a0models.CharField(max_length=30)<\/span><\/code><code><span class=\"code-snippet_outer\">    email = models.EmailField(blank=True)<\/span><\/code><code><span class=\"code-snippet_outer\">    birth_date = models.DateField()<\/span><\/code><code><span class=\"code-snippet_outer\">    location = models.CharField(max_length=100, blank=True)<\/span><\/code><\/pre>\n<\/section>\n<p style=\"box-sizing: border-box; color: #3e454c; margin-top: 1em; margin-bottom: 1.5em; vertical-align: baseline; word-break: break-word; line-height: 1.5; font-family: Nunito, sans-serif; font-size: 15.4px; text-align: start; white-space: normal; background-color: #ffffff; border: 0px initial initial;\"><span style=\"box-sizing: border-box; color: inherit; font-weight: bold; vertical-align: baseline; border: 0px initial initial;\">resources.py<\/span><\/p>\n<section class=\"code-snippet__fix code-snippet__js\">\n<ul class=\"code-snippet__line-index code-snippet__js\">\n<li><\/li>\n<li><\/li>\n<li><\/li>\n<li><\/li>\n<li><\/li>\n<li><\/li>\n<\/ul>\n<pre class=\"code-snippet__js\"><code><span class=\"code-snippet_outer\">from import_export import resources<\/span><\/code><code><span class=\"code-snippet_outer\">from .models import Person<\/span><\/code><code><span class=\"code-snippet_outer\">\n<\/span><\/code><code><span class=\"code-snippet_outer\">class PersonResource(resources.ModelResource):<\/span><\/code><code><span class=\"code-snippet_outer\">    class\u00a0Meta:<\/span><\/code><code><span class=\"code-snippet_outer\">\u00a0\u00a0\u00a0\u00a0    model\u00a0=\u00a0Person<\/span><\/code><\/pre>\n<\/section>\n<p style=\"box-sizing: border-box; color: #3e454c; margin-top: 1em; margin-bottom: 1.5em; vertical-align: baseline; word-break: break-word; line-height: 1.5; font-family: Nunito, sans-serif; font-size: 15.4px; text-align: start; white-space: normal; background-color: #ffffff; border: 0px initial initial;\"><span style=\"color: #888888;\"><span style=\"box-sizing: border-box; vertical-align: baseline; font-variant-numeric: normal; font-variant-east-asian: normal; line-height: 18px; border: 0px initial initial;\">\u8fd9\u662f\u6700\u7b80\u5355\u7684\u5b9a\u4e49\u3002\u60a8\u53ef\u4ee5\u5c06\u51e0\u4e2a\u914d\u7f6e\u4f20\u9012\u7ed9\u5143\u7c7b\uff0c<\/span>\u5982<\/span>\uff1a<code style=\"box-sizing: border-box; color: #505050; font-family: Menlo, Monaco, Consolas, 'Courier New', monospace; font-size: 0.8em; padding: 0.2em 0.4em; background-color: #f2f2f2; border-radius: 3px;\">fields<\/code>,\u00a0<code style=\"box-sizing: border-box; color: #505050; font-family: Menlo, Monaco, Consolas, 'Courier New', monospace; font-size: 0.8em; padding: 0.2em 0.4em; background-color: #f2f2f2; border-radius: 3px;\">exclude<\/code><\/p>\n<h4 style=\"box-sizing: border-box; color: #3e454c; font-family: Nunito, sans-serif; line-height: 1.35; font-size: 18px; vertical-align: baseline; word-break: break-word; white-space: normal; background-color: #ffffff; text-align: left; border: 0px initial initial;\"><span style=\"color: #ffa900;\"><strong><span style=\"font-size: 17px;\">\u5bfc\u51fa\u6570\u636e<\/span><\/strong><\/span><\/h4>\n<p style=\"box-sizing: border-box; color: #3e454c; margin-top: 1em; margin-bottom: 1.5em; vertical-align: baseline; word-break: break-word; line-height: 1.5; font-family: Nunito, sans-serif; font-size: 15.4px; text-align: start; white-space: normal; background-color: #ffffff; border: 0px initial initial;\"><span style=\"color: #888888;\"><span style=\"box-sizing: border-box; vertical-align: baseline; font-variant-numeric: normal; font-variant-east-asian: normal; line-height: 18px; border: 0px initial initial;\">\u5bfc\u51fa\u6570\u636e<\/span>\u5230CSV<\/span><\/p>\n<pre style=\"box-sizing: border-box; color: #191919; overflow: auto; font-family: inconsolata, monospace; font-size: 12px; padding: 0.5em 0.5em 0.5em 15px; margin-top: 20px; margin-bottom: 20px; line-height: 1.45; word-break: break-all; overflow-wrap: normal; background: #fafafa; border-width: 0px 0px 0px 1px; border-radius: 0px; vertical-align: baseline; clear: left; letter-spacing: 0.3px; word-spacing: 1px; text-align: start; border-color: initial initial initial #aec8da; border-style: initial initial initial solid;\">from\u00a0.resources\u00a0<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">import<\/span>\u00a0PersonResource\nperson_resource\u00a0=\u00a0PersonResource()\ndataset\u00a0=\u00a0person_resource.<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">export<\/span>()\ndataset.csv<\/pre>\n<pre style=\"box-sizing: border-box; color: #191919; overflow: auto; font-family: inconsolata, monospace; font-size: 12px; padding: 0.5em 0.5em 0.5em 15px; margin-top: 20px; margin-bottom: 20px; line-height: 1.45; word-break: break-all; overflow-wrap: normal; background: #fafafa; border-width: 0px 0px 0px 1px; border-radius: 0px; vertical-align: baseline; clear: left; letter-spacing: 0.3px; word-spacing: 1px; text-align: start; border-color: initial initial initial #aec8da; border-style: initial initial initial solid;\"><span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">id<\/span>,<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">name<\/span>,<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">email<\/span>,<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">birth_date<\/span>,<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">location<\/span>\n1,<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">John<\/span>,<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">john<\/span>@<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">doe<\/span>.<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">com<\/span>,<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">2016<\/span>-<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">08<\/span>-<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">11<\/span>,<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">Helsinki<\/span>\n<span style=\"box-sizing: border-box; color: #990055; vertical-align: baseline; border: 0px initial initial;\">2<\/span>,Peter,peter@example.com,<span style=\"box-sizing: border-box; color: #990055; vertical-align: baseline; border: 0px initial initial;\">2016<\/span>-<span style=\"box-sizing: border-box; color: #990055; vertical-align: baseline; border: 0px initial initial;\">08<\/span>-<span style=\"box-sizing: border-box; color: #990055; vertical-align: baseline; border: 0px initial initial;\">11<\/span>,Helsinki\n<span style=\"box-sizing: border-box; color: #990055; vertical-align: baseline; border: 0px initial initial;\">3<\/span>,Maria,maria@gmail.com,<span style=\"box-sizing: border-box; color: #990055; vertical-align: baseline; border: 0px initial initial;\">2016<\/span>-<span style=\"box-sizing: border-box; color: #990055; vertical-align: baseline; border: 0px initial initial;\">08<\/span>-<span style=\"box-sizing: border-box; color: #990055; vertical-align: baseline; border: 0px initial initial;\">11<\/span>,Barcelona\n<span style=\"box-sizing: border-box; color: #990055; vertical-align: baseline; border: 0px initial initial;\">4<\/span>,Vitor,vitor@freitas.com,<span style=\"box-sizing: border-box; color: #990055; vertical-align: baseline; border: 0px initial initial;\">2016<\/span>-<span style=\"box-sizing: border-box; color: #990055; vertical-align: baseline; border: 0px initial initial;\">08<\/span>-<span style=\"box-sizing: border-box; color: #990055; vertical-align: baseline; border: 0px initial initial;\">11<\/span>,Oulu\n<span style=\"box-sizing: border-box; color: #990055; vertical-align: baseline; border: 0px initial initial;\">5<\/span>,Erica,erica@gmail.com,<span style=\"box-sizing: border-box; color: #990055; vertical-align: baseline; border: 0px initial initial;\">2016<\/span>-<span style=\"box-sizing: border-box; color: #990055; vertical-align: baseline; border: 0px initial initial;\">08<\/span>-<span style=\"box-sizing: border-box; color: #990055; vertical-align: baseline; border: 0px initial initial;\">11<\/span>,Oulu<\/pre>\n<p style=\"box-sizing: border-box; color: #3e454c; margin-top: 1em; margin-bottom: 1.5em; vertical-align: baseline; word-break: break-word; line-height: 1.5; font-family: Nunito, sans-serif; font-size: 15.4px; text-align: start; white-space: normal; background-color: #ffffff; border: 0px initial initial;\"><span style=\"color: #888888;\">\u5bfc\u51fa\u6570\u636e\u5230JSON<\/span><\/p>\n<pre style=\"box-sizing: border-box; color: #191919; overflow: auto; font-family: inconsolata, monospace; font-size: 12px; padding: 0.5em 0.5em 0.5em 15px; margin-top: 20px; margin-bottom: 20px; line-height: 1.45; word-break: break-all; overflow-wrap: normal; background: #fafafa; border-width: 0px 0px 0px 1px; border-radius: 0px; vertical-align: baseline; clear: left; letter-spacing: 0.3px; word-spacing: 1px; text-align: start; border-color: initial initial initial #aec8da; border-style: initial initial initial solid;\"><span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">dataset<\/span><span style=\"box-sizing: border-box; color: #669900; vertical-align: baseline; border: 0px initial initial;\">.json<\/span><\/pre>\n<pre style=\"box-sizing: border-box; color: #191919; overflow: auto; font-family: inconsolata, monospace; font-size: 12px; padding: 0.5em 0.5em 0.5em 15px; margin-top: 20px; margin-bottom: 20px; line-height: 1.45; word-break: break-all; overflow-wrap: normal; background: #fafafa; border-width: 0px 0px 0px 1px; border-radius: 0px; vertical-align: baseline; clear: left; letter-spacing: 0.3px; word-spacing: 1px; text-align: start; border-color: initial initial initial #aec8da; border-style: initial initial initial solid;\">[\n\u00a0\u00a0{<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">\"id\"<\/span>:\u00a0<span style=\"box-sizing: border-box; color: #990055; vertical-align: baseline; border: 0px initial initial;\">1<\/span>,\u00a0<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">\"name\"<\/span>:\u00a0<span style=\"box-sizing: border-box; color: #669900; vertical-align: baseline; border: 0px initial initial;\">\"John\"<\/span>,\u00a0<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">\"email\"<\/span>:\u00a0<span style=\"box-sizing: border-box; color: #669900; vertical-align: baseline; border: 0px initial initial;\">\"john@doe.com\"<\/span>,\u00a0<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">\"birth_date\"<\/span>:\u00a0<span style=\"box-sizing: border-box; color: #669900; vertical-align: baseline; border: 0px initial initial;\">\"2016-08-11\"<\/span>,\u00a0<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">\"location\"<\/span>:\u00a0<span style=\"box-sizing: border-box; color: #669900; vertical-align: baseline; border: 0px initial initial;\">\"Helsinki\"<\/span>},\n\u00a0\u00a0{<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">\"id\"<\/span>:\u00a0<span style=\"box-sizing: border-box; color: #990055; vertical-align: baseline; border: 0px initial initial;\">2<\/span>,\u00a0<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">\"name\"<\/span>:\u00a0<span style=\"box-sizing: border-box; color: #669900; vertical-align: baseline; border: 0px initial initial;\">\"Peter\"<\/span>,\u00a0<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">\"email\"<\/span>:\u00a0<span style=\"box-sizing: border-box; color: #669900; vertical-align: baseline; border: 0px initial initial;\">\"peter@example.com\"<\/span>,\u00a0<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">\"birth_date\"<\/span>:\u00a0<span style=\"box-sizing: border-box; color: #669900; vertical-align: baseline; border: 0px initial initial;\">\"2016-08-11\"<\/span>,\u00a0<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">\"location\"<\/span>:\u00a0<span style=\"box-sizing: border-box; color: #669900; vertical-align: baseline; border: 0px initial initial;\">\"Helsinki\"<\/span>},\n\u00a0\u00a0{<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">\"id\"<\/span>:\u00a0<span style=\"box-sizing: border-box; color: #990055; vertical-align: baseline; border: 0px initial initial;\">3<\/span>,\u00a0<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">\"name\"<\/span>:\u00a0<span style=\"box-sizing: border-box; color: #669900; vertical-align: baseline; border: 0px initial initial;\">\"Maria\"<\/span>,\u00a0<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">\"email\"<\/span>:\u00a0<span style=\"box-sizing: border-box; color: #669900; vertical-align: baseline; border: 0px initial initial;\">\"maria@gmail.com\"<\/span>,\u00a0<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">\"birth_date\"<\/span>:\u00a0<span style=\"box-sizing: border-box; color: #669900; vertical-align: baseline; border: 0px initial initial;\">\"2016-08-11\"<\/span>,\u00a0<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">\"location\"<\/span>:\u00a0<span style=\"box-sizing: border-box; color: #669900; vertical-align: baseline; border: 0px initial initial;\">\"Barcelona\"<\/span>},\n\u00a0\u00a0{<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">\"id\"<\/span>:\u00a0<span style=\"box-sizing: border-box; color: #990055; vertical-align: baseline; border: 0px initial initial;\">4<\/span>,\u00a0<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">\"name\"<\/span>:\u00a0<span style=\"box-sizing: border-box; color: #669900; vertical-align: baseline; border: 0px initial initial;\">\"Vitor\"<\/span>,\u00a0<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">\"email\"<\/span>:\u00a0<span style=\"box-sizing: border-box; color: #669900; vertical-align: baseline; border: 0px initial initial;\">\"vitor@freitas.com\"<\/span>,\u00a0<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">\"birth_date\"<\/span>:\u00a0<span style=\"box-sizing: border-box; color: #669900; vertical-align: baseline; border: 0px initial initial;\">\"2016-08-11\"<\/span>,\u00a0<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">\"location\"<\/span>:\u00a0<span style=\"box-sizing: border-box; color: #669900; vertical-align: baseline; border: 0px initial initial;\">\"Oulu\"<\/span>},\n\u00a0\u00a0{<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">\"id\"<\/span>:\u00a0<span style=\"box-sizing: border-box; color: #990055; vertical-align: baseline; border: 0px initial initial;\">5<\/span>,\u00a0<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">\"name\"<\/span>:\u00a0<span style=\"box-sizing: border-box; color: #669900; vertical-align: baseline; border: 0px initial initial;\">\"Erica\"<\/span>,\u00a0<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">\"email\"<\/span>:\u00a0<span style=\"box-sizing: border-box; color: #669900; vertical-align: baseline; border: 0px initial initial;\">\"erica@gmail.com\"<\/span>,\u00a0<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">\"birth_date\"<\/span>:\u00a0<span style=\"box-sizing: border-box; color: #669900; vertical-align: baseline; border: 0px initial initial;\">\"2016-08-11\"<\/span>,\u00a0<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">\"location\"<\/span>:\u00a0<span style=\"box-sizing: border-box; color: #669900; vertical-align: baseline; border: 0px initial initial;\">\"Oulu\"<\/span>}\n]<\/pre>\n<p style=\"box-sizing: border-box; color: #3e454c; margin-top: 1em; margin-bottom: 1.5em; vertical-align: baseline; word-break: break-word; line-height: 1.5; font-family: Nunito, sans-serif; font-size: 15.4px; text-align: start; white-space: normal; background-color: #ffffff; border: 0px initial initial;\"><span style=\"color: #888888;\">\u5bfc\u51fa\u6570\u636e\u5230YAML<\/span><\/p>\n<pre style=\"box-sizing: border-box; color: #191919; overflow: auto; font-family: inconsolata, monospace; font-size: 12px; padding: 0.5em 0.5em 0.5em 15px; margin-top: 20px; margin-bottom: 20px; line-height: 1.45; word-break: break-all; overflow-wrap: normal; background: #fafafa; border-width: 0px 0px 0px 1px; border-radius: 0px; vertical-align: baseline; clear: left; letter-spacing: 0.3px; word-spacing: 1px; text-align: start; border-color: initial initial initial #aec8da; border-style: initial initial initial solid;\"><span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">dataset<\/span><span style=\"box-sizing: border-box; color: #669900; vertical-align: baseline; border: 0px initial initial;\">.yaml<\/span><\/pre>\n<pre style=\"box-sizing: border-box; color: #191919; overflow: auto; font-family: inconsolata, monospace; font-size: 12px; padding: 0.5em 0.5em 0.5em 15px; margin-top: 20px; margin-bottom: 20px; line-height: 1.45; word-break: break-all; overflow-wrap: normal; background: #fafafa; border-width: 0px 0px 0px 1px; border-radius: 0px; vertical-align: baseline; clear: left; letter-spacing: 0.3px; word-spacing: 1px; text-align: start; border-color: initial initial initial #aec8da; border-style: initial initial initial solid;\"><span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">-<\/span>\u00a0{<span style=\"box-sizing: border-box; color: #dd4a68; vertical-align: baseline; border: 0px initial initial;\">birth_date<\/span>:\u00a0<span style=\"box-sizing: border-box; color: #669900; vertical-align: baseline; border: 0px initial initial;\">'2016-08-11'<\/span>,\u00a0email:\u00a0john@doe.com,\u00a0id:\u00a0<span style=\"box-sizing: border-box; color: #990055; vertical-align: baseline; border: 0px initial initial;\">1<\/span>,\u00a0location:\u00a0Helsinki,\u00a0name:\u00a0John}\n<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">-<\/span>\u00a0{<span style=\"box-sizing: border-box; color: #dd4a68; vertical-align: baseline; border: 0px initial initial;\">birth_date<\/span>:\u00a0<span style=\"box-sizing: border-box; color: #669900; vertical-align: baseline; border: 0px initial initial;\">'2016-08-11'<\/span>,\u00a0email:\u00a0peter@example.com,\u00a0id:\u00a0<span style=\"box-sizing: border-box; color: #990055; vertical-align: baseline; border: 0px initial initial;\">2<\/span>,\u00a0location:\u00a0Helsinki,\u00a0name:\u00a0Peter}\n<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">-<\/span>\u00a0{<span style=\"box-sizing: border-box; color: #dd4a68; vertical-align: baseline; border: 0px initial initial;\">birth_date<\/span>:\u00a0<span style=\"box-sizing: border-box; color: #669900; vertical-align: baseline; border: 0px initial initial;\">'2016-08-11'<\/span>,\u00a0email:\u00a0maria@gmail.com,\u00a0id:\u00a0<span style=\"box-sizing: border-box; color: #990055; vertical-align: baseline; border: 0px initial initial;\">3<\/span>,\u00a0location:\u00a0Barcelona,\u00a0name:\u00a0Maria}\n<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">-<\/span>\u00a0{<span style=\"box-sizing: border-box; color: #dd4a68; vertical-align: baseline; border: 0px initial initial;\">birth_date<\/span>:\u00a0<span style=\"box-sizing: border-box; color: #669900; vertical-align: baseline; border: 0px initial initial;\">'2016-08-11'<\/span>,\u00a0email:\u00a0vitor@freitas.com,\u00a0id:\u00a0<span style=\"box-sizing: border-box; color: #990055; vertical-align: baseline; border: 0px initial initial;\">4<\/span>,\u00a0location:\u00a0Oulu,\u00a0name:\u00a0Vitor}\n<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">-<\/span>\u00a0{<span style=\"box-sizing: border-box; color: #dd4a68; vertical-align: baseline; border: 0px initial initial;\">birth_date<\/span>:\u00a0<span style=\"box-sizing: border-box; color: #669900; vertical-align: baseline; border: 0px initial initial;\">'2016-08-11'<\/span>,\u00a0email:\u00a0erica@gmail.com,\u00a0id:\u00a0<span style=\"box-sizing: border-box; color: #990055; vertical-align: baseline; border: 0px initial initial;\">5<\/span>,\u00a0location:\u00a0Oulu,\u00a0name:\u00a0Erica}<\/pre>\n<p style=\"box-sizing: border-box; color: #3e454c; margin-top: 1em; margin-bottom: 1.5em; vertical-align: baseline; word-break: break-word; line-height: 1.5; font-family: Nunito, sans-serif; font-size: 15.4px; text-align: start; white-space: normal; background-color: #ffffff; border: 0px initial initial;\"><span style=\"box-sizing: border-box; vertical-align: baseline; font-variant-numeric: normal; font-variant-east-asian: normal; line-height: 18px; color: #888888; border: 0px initial initial;\">\u8fc7\u6ee4\u6570\u636e<\/span><\/p>\n<pre style=\"box-sizing: border-box; color: #191919; overflow: auto; font-family: inconsolata, monospace; font-size: 12px; padding: 0.5em 0.5em 0.5em 15px; margin-top: 20px; margin-bottom: 20px; line-height: 1.45; word-break: break-all; overflow-wrap: normal; background: #fafafa; border-width: 0px 0px 0px 1px; border-radius: 0px; vertical-align: baseline; clear: left; letter-spacing: 0.3px; word-spacing: 1px; text-align: start; border-color: initial initial initial #aec8da; border-style: initial initial initial solid;\"><span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">from<\/span>\u00a0.resources\u00a0<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">import<\/span>\u00a0PersonResource\n<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">from<\/span>\u00a0.models\u00a0<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">import<\/span>\u00a0Person\nperson_resource\u00a0=\u00a0PersonResource()\nqueryset\u00a0=\u00a0Person.objects.filter(location=<span style=\"box-sizing: border-box; color: #669900; vertical-align: baseline; border: 0px initial initial;\">'Helsinki'<\/span>)\ndataset\u00a0=\u00a0person_resource.export(queryset)\ndataset.yaml<\/pre>\n<pre style=\"box-sizing: border-box; color: #191919; overflow: auto; font-family: inconsolata, monospace; font-size: 12px; padding: 0.5em 0.5em 0.5em 15px; margin-top: 20px; margin-bottom: 20px; line-height: 1.45; word-break: break-all; overflow-wrap: normal; background: #fafafa; border-width: 0px 0px 0px 1px; border-radius: 0px; vertical-align: baseline; clear: left; letter-spacing: 0.3px; word-spacing: 1px; text-align: start; border-color: initial initial initial #aec8da; border-style: initial initial initial solid;\"><span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">-<\/span>\u00a0{<span style=\"box-sizing: border-box; color: #dd4a68; vertical-align: baseline; border: 0px initial initial;\">birth_date<\/span>:\u00a0<span style=\"box-sizing: border-box; color: #669900; vertical-align: baseline; border: 0px initial initial;\">'2016-08-11'<\/span>,\u00a0email:\u00a0john@doe.com,\u00a0id:\u00a0<span style=\"box-sizing: border-box; color: #990055; vertical-align: baseline; border: 0px initial initial;\">1<\/span>,\u00a0location:\u00a0Helsinki,\u00a0name:\u00a0John}\n<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">-<\/span>\u00a0{<span style=\"box-sizing: border-box; color: #dd4a68; vertical-align: baseline; border: 0px initial initial;\">birth_date<\/span>:\u00a0<span style=\"box-sizing: border-box; color: #669900; vertical-align: baseline; border: 0px initial initial;\">'2016-08-11'<\/span>,\u00a0email:\u00a0peter@example.com,\u00a0id:\u00a0<span style=\"box-sizing: border-box; color: #990055; vertical-align: baseline; border: 0px initial initial;\">2<\/span>,\u00a0location:\u00a0Helsinki,\u00a0name:\u00a0Peter}<\/pre>\n<p style=\"box-sizing: border-box; color: #3e454c; margin-top: 1em; margin-bottom: 1.5em; vertical-align: baseline; word-break: break-word; line-height: 1.5; font-family: Nunito, sans-serif; font-size: 15.4px; text-align: start; white-space: normal; background-color: #ffffff; border: 0px initial initial;\"><span style=\"box-sizing: border-box; vertical-align: baseline; font-variant-numeric: normal; font-variant-east-asian: normal; line-height: 18px; color: #888888; border: 0px initial initial;\">\u5bfc\u51fa\u5230CSV\u89c6\u56fe<\/span><\/p>\n<section class=\"code-snippet__fix code-snippet__js\">\n<ul class=\"code-snippet__line-index code-snippet__js\">\n<li><\/li>\n<li><\/li>\n<li><\/li>\n<li><\/li>\n<li><\/li>\n<li><\/li>\n<li><\/li>\n<li><\/li>\n<li><\/li>\n<\/ul>\n<pre class=\"code-snippet__js\"><code><span class=\"code-snippet_outer\">from django.http import HttpResponse<\/span><\/code><code><span class=\"code-snippet_outer\">from .resources import PersonResource<\/span><\/code><code><span class=\"code-snippet_outer\">\n<\/span><\/code><code><span class=\"code-snippet_outer\">def\u00a0export(request):<\/span><\/code><code><span class=\"code-snippet_outer\">    person_resource\u00a0=\u00a0PersonResource()<\/span><\/code><code><span class=\"code-snippet_outer\">\u00a0\u00a0\u00a0\u00a0dataset\u00a0=\u00a0person_resource.export()<\/span><\/code><code><span class=\"code-snippet_outer\">\u00a0\u00a0\u00a0\u00a0response\u00a0=\u00a0HttpResponse(dataset.csv,\u00a0content_type='text\/csv')<\/span><\/code><code><span class=\"code-snippet_outer\">\u00a0\u00a0\u00a0\u00a0response['Content-Disposition']\u00a0=\u00a0'attachment;\u00a0filename=\"persons.csv\"'<\/span><\/code><code><span class=\"code-snippet_outer\">\u00a0\u00a0\u00a0\u00a0return\u00a0response<\/span><\/code><\/pre>\n<\/section>\n<p style=\"box-sizing: border-box; color: #3e454c; margin-top: 1em; margin-bottom: 1.5em; vertical-align: baseline; word-break: break-word; line-height: 1.5; font-family: Nunito, sans-serif; font-size: 15.4px; text-align: start; white-space: normal; background-color: #ffffff; border: 0px initial initial;\"><span style=\"box-sizing: border-box; vertical-align: baseline; font-variant-numeric: normal; font-variant-east-asian: normal; line-height: 18px; color: #888888; border: 0px initial initial;\">\u5bfc\u51fa\u5230Excel\u89c6\u56fe<\/span><\/p>\n<section class=\"code-snippet__fix code-snippet__js\">\n<ul class=\"code-snippet__line-index code-snippet__js\">\n<li><\/li>\n<li><\/li>\n<li><\/li>\n<li><\/li>\n<li><\/li>\n<li><\/li>\n<li><\/li>\n<li><\/li>\n<li><\/li>\n<\/ul>\n<pre class=\"code-snippet__js\"><code><span class=\"code-snippet_outer\">from django.http import HttpResponse<\/span><\/code><code><span class=\"code-snippet_outer\">from .resources import PersonResource<\/span><\/code><code><span class=\"code-snippet_outer\">\n<\/span><\/code><code><span class=\"code-snippet_outer\">def\u00a0export(request):<\/span><\/code><code><span class=\"code-snippet_outer\">\u00a0\u00a0\u00a0\u00a0person_resource\u00a0=\u00a0PersonResource()<\/span><\/code><code><span class=\"code-snippet_outer\">\u00a0\u00a0\u00a0\u00a0dataset\u00a0=\u00a0person_resource.export()<\/span><\/code><code><span class=\"code-snippet_outer\">\u00a0\u00a0\u00a0\u00a0response\u00a0=\u00a0HttpResponse(dataset.xls,\u00a0content_type='application\/vnd.ms-excel')<\/span><\/code><code><span class=\"code-snippet_outer\">\u00a0\u00a0\u00a0\u00a0response['Content-Disposition']\u00a0=\u00a0'attachment;\u00a0filename=\"persons.xls\"'<\/span><\/code><code><span class=\"code-snippet_outer\">\u00a0\u00a0\u00a0\u00a0return\u00a0response<\/span><\/code><\/pre>\n<\/section>\n<p style=\"box-sizing: border-box; color: #3e454c; margin-top: 1em; margin-bottom: 1.5em; vertical-align: baseline; word-break: break-word; line-height: 1.5; font-family: Nunito, sans-serif; font-size: 15.4px; white-space: normal; background-color: #ffffff; text-align: left; border: 0px initial initial;\"><span style=\"color: #ffa900; font-size: 17px;\"><strong>\u5bfc\u5165\u6570\u636e<\/strong><\/span><\/p>\n<p style=\"box-sizing: border-box; color: #3e454c; margin-top: 1em; margin-bottom: 1.5em; vertical-align: baseline; word-break: break-word; line-height: 1.5; font-family: Nunito, sans-serif; font-size: 15.4px; text-align: start; white-space: normal; background-color: #ffffff; border: 0px initial initial;\"><span style=\"color: #888888;\">\u67e5\u770b<span style=\"box-sizing: border-box; font-weight: bold; vertical-align: baseline; border: 0px initial initial;\">new_persons.csv<\/span>\u7684\u6570\u636e<\/span>\uff1a<\/p>\n<pre style=\"box-sizing: border-box; color: #191919; overflow: auto; font-family: inconsolata, monospace; font-size: 12px; padding: 0.5em 0.5em 0.5em 15px; margin-top: 20px; margin-bottom: 20px; line-height: 1.45; word-break: break-all; overflow-wrap: normal; background: #fafafa; border-width: 0px 0px 0px 1px; border-radius: 0px; vertical-align: baseline; clear: left; letter-spacing: 0.3px; word-spacing: 1px; text-align: start; border-color: initial initial initial #aec8da; border-style: initial initial initial solid;\"><span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">name<\/span>,<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">email<\/span>,<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">birth_date<\/span>,<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">location<\/span>,<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">id<\/span>\n<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">Jessica<\/span>,<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">jessica<\/span>@<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">jones<\/span>.<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">com<\/span>,<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">2016<\/span>-<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">08<\/span>-<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">11<\/span>,<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">New<\/span>\u00a0York,\nMikko,mikko@suomi.com,<span style=\"box-sizing: border-box; color: #990055; vertical-align: baseline; border: 0px initial initial;\">2016<\/span>-<span style=\"box-sizing: border-box; color: #990055; vertical-align: baseline; border: 0px initial initial;\">08<\/span>-<span style=\"box-sizing: border-box; color: #990055; vertical-align: baseline; border: 0px initial initial;\">11<\/span>,Jyv\u00e4skyla,<\/pre>\n<p style=\"box-sizing: border-box; color: #3e454c; margin-top: 1em; margin-bottom: 1.5em; vertical-align: baseline; word-break: break-word; line-height: 1.5; font-family: Nunito, sans-serif; font-size: 15.4px; text-align: start; white-space: normal; background-color: #ffffff; border: 0px initial initial;\"><span style=\"box-sizing: border-box; vertical-align: baseline; font-variant-numeric: normal; font-variant-east-asian: normal; line-height: 18px; color: #888888; border: 0px initial initial;\">id\u5fc5\u987b\u5b58\u5728\uff0c\u56e0\u4e3a\u5b83\u662f\u4e3b\u952e\u3002\u4f46\u662f\u5b83\u4f1a\u751f\u6210\uff0c\u6240\u4ee5\u6211\u4eec\u4e0d\u9700\u8981\u6307\u5b9a\u503c\u3002<\/span><\/p>\n<p style=\"box-sizing: border-box; color: #3e454c; margin-top: 1em; margin-bottom: 1.5em; vertical-align: baseline; word-break: break-word; line-height: 1.5; font-family: Nunito, sans-serif; font-size: 15.4px; text-align: start; white-space: normal; background-color: #ffffff; border: 0px initial initial;\"><span style=\"box-sizing: border-box; font-variant-numeric: normal; font-variant-east-asian: normal; line-height: 18px; vertical-align: baseline; color: #888888; border: 0px initial initial;\">import.html<\/span><\/p>\n<pre style=\"box-sizing: border-box; color: #191919; overflow: auto; font-family: inconsolata, monospace; font-size: 12px; padding: 0.5em 0.5em 0.5em 15px; margin-top: 20px; margin-bottom: 20px; line-height: 1.45; word-break: break-all; overflow-wrap: normal; background: #fafafa; border-width: 0px 0px 0px 1px; border-radius: 0px; vertical-align: baseline; clear: left; letter-spacing: 0.3px; word-spacing: 1px; text-align: start; border-color: initial initial initial #aec8da; border-style: initial initial initial solid;\">{%\u00a0extends\u00a0'base.html'\u00a0%}\n{%\u00a0block\u00a0content\u00a0%}\n\u00a0\u00a0<span style=\"box-sizing: border-box; color: #999999; vertical-align: baseline; border: 0px initial initial;\">&lt;form\u00a0method=\"post\"\u00a0enctype=\"multipart\/form-data\"&gt;<\/span>\n\u00a0\u00a0\u00a0\u00a0{%\u00a0csrf_token\u00a0%}\n\u00a0\u00a0\u00a0\u00a0<span style=\"box-sizing: border-box; color: #999999; vertical-align: baseline; border: 0px initial initial;\">&lt;input\u00a0type=\"file\"\u00a0name=\"myfile\"&gt;<\/span>\n\u00a0\u00a0\u00a0\u00a0<span style=\"box-sizing: border-box; color: #999999; vertical-align: baseline; border: 0px initial initial;\">&lt;button\u00a0type=\"submit\"&gt;<\/span>Upload<span style=\"box-sizing: border-box; color: #999999; vertical-align: baseline; border: 0px initial initial;\">&lt;\/button&gt;<\/span>\n\u00a0\u00a0<span style=\"box-sizing: border-box; color: #999999; vertical-align: baseline; border: 0px initial initial;\">&lt;\/form&gt;<\/span>\n{%\u00a0endblock\u00a0%}<\/pre>\n<p style=\"box-sizing: border-box; color: #3e454c; margin-top: 1em; margin-bottom: 1.5em; vertical-align: baseline; word-break: break-word; line-height: 1.5; font-family: Nunito, sans-serif; font-size: 15.4px; text-align: start; white-space: normal; background-color: #ffffff; border: 0px initial initial;\"><span style=\"box-sizing: border-box; color: inherit; font-weight: bold; vertical-align: baseline; border: 0px initial initial;\">views.py<\/span><\/p>\n<section class=\"code-snippet__fix code-snippet__js\">\n<ul class=\"code-snippet__line-index code-snippet__js\">\n<li><\/li>\n<li><\/li>\n<li><\/li>\n<li><\/li>\n<li><\/li>\n<li><\/li>\n<li><\/li>\n<li><\/li>\n<li><\/li>\n<li><\/li>\n<li><\/li>\n<\/ul>\n<pre class=\"code-snippet__js\"><code><span class=\"code-snippet_outer\">from tablib import Dataset<\/span><\/code><code><span class=\"code-snippet_outer\">def\u00a0simple_upload(request):<\/span><\/code><code><span class=\"code-snippet_outer\">    if\u00a0request.method\u00a0==\u00a0'POST':<\/span><\/code><code><span class=\"code-snippet_outer\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0person_resource\u00a0=\u00a0PersonResource()<\/span><\/code><code><span class=\"code-snippet_outer\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0dataset\u00a0=\u00a0Dataset()<\/span><\/code><code><span class=\"code-snippet_outer\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0new_persons\u00a0=\u00a0request.FILES['myfile']<\/span><\/code><code><span class=\"code-snippet_outer\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0imported_data\u00a0=\u00a0dataset.load(new_persons.read())<\/span><\/code><code><span class=\"code-snippet_outer\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0result\u00a0=\u00a0person_resource.import_data(dataset,\u00a0dry_run=True)\u00a0\u00a0#\u00a0Test\u00a0the\u00a0data\u00a0impor<\/span><\/code><code><span class=\"code-snippet_outer\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0if\u00a0not\u00a0result.has_errors():<\/span><\/code><code><span class=\"code-snippet_outer\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0person_resource.import_data(dataset,\u00a0dry_run=False)\u00a0\u00a0#\u00a0Actually\u00a0import\u00a0now<\/span><\/code><code><span class=\"code-snippet_outer\">\u00a0\u00a0\u00a0\u00a0\u00a0return\u00a0render(request,\u00a0'core\/simple_upload.html')<\/span><\/code><\/pre>\n<\/section>\n<h3 style=\"box-sizing: border-box; color: #3e454c; font-family: Nunito, sans-serif; font-weight: bold; line-height: 1.35; margin-bottom: 1em; font-size: 1em; vertical-align: baseline; word-break: break-word; text-align: start; white-space: normal; background-color: #ffffff; border: 0px initial initial;\"><\/h3>\n<h3 style=\"box-sizing: border-box; color: #3e454c; font-family: Nunito, sans-serif; font-weight: bold; line-height: 1.35; margin-bottom: 1em; font-size: 1em; vertical-align: baseline; word-break: break-word; text-align: start; white-space: normal; background-color: #ffffff; border: 0px initial initial;\"><span style=\"color: #ffa900;\"><strong><span style=\"font-size: 17px;\">Django\u540e\u53f0\u7ba1\u7406\u96c6\u6210<\/span><\/strong><\/span><\/h3>\n<p style=\"box-sizing: border-box; color: #3e454c; margin-top: 1em; margin-bottom: 1.5em; vertical-align: baseline; word-break: break-word; line-height: 1.5; font-family: Nunito, sans-serif; font-size: 15.4px; text-align: start; white-space: normal; background-color: #ffffff; border: 0px initial initial;\"><span style=\"color: #888888;\">\u5728admin.py\u91cc\u4f7f\u7528<\/span><code style=\"box-sizing: border-box; color: #505050; font-family: Menlo, Monaco, Consolas, 'Courier New', monospace; font-size: 0.8em; padding: 0.2em 0.4em; background-color: #f2f2f2; border-radius: 3px;\">ImportExportModelAdmin<\/code><span style=\"color: #888888;\">\uff0c\u800c\u4e0d\u662f<\/span><code style=\"box-sizing: border-box; color: #505050; font-family: Menlo, Monaco, Consolas, 'Courier New', monospace; font-size: 0.8em; padding: 0.2em 0.4em; background-color: #f2f2f2; border-radius: 3px;\">ModelAdmin<\/code><\/p>\n<pre style=\"box-sizing: border-box; color: #191919; overflow: auto; font-family: inconsolata, monospace; font-size: 12px; padding: 0.5em 0.5em 0.5em 15px; margin-top: 20px; margin-bottom: 20px; line-height: 1.45; word-break: break-all; overflow-wrap: normal; background: #fafafa; border-width: 0px 0px 0px 1px; border-radius: 0px; vertical-align: baseline; clear: left; letter-spacing: 0.3px; word-spacing: 1px; text-align: start; border-color: initial initial initial #aec8da; border-style: initial initial initial solid;\"><span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">from<\/span>\u00a0import_export.admin\u00a0<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">import<\/span>\u00a0ImportExportModelAdmin\n<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">from<\/span>\u00a0django.contrib\u00a0<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">import<\/span>\u00a0admin<\/pre>\n<p><span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">from<\/span>\u00a0.models\u00a0<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">import<\/span>\u00a0Person<\/p>\n<pre style=\"box-sizing: border-box; color: #191919; overflow: auto; font-family: inconsolata, monospace; font-size: 12px; padding: 0.5em 0.5em 0.5em 15px; margin-top: 20px; margin-bottom: 20px; line-height: 1.45; word-break: break-all; overflow-wrap: normal; background: #fafafa; border-width: 0px 0px 0px 1px; border-radius: 0px; vertical-align: baseline; clear: left; letter-spacing: 0.3px; word-spacing: 1px; text-align: start; border-color: initial initial initial #aec8da; border-style: initial initial initial solid;\"><span style=\"box-sizing: border-box; color: inherit; vertical-align: baseline; border: 0px initial initial;\">@admin.register(Person)<\/span>\n<span style=\"box-sizing: border-box; color: inherit; vertical-align: baseline; border: 0px initial initial;\">class\u00a0PersonAdmin(ImportExportModelAdmin):<\/span>\n\u00a0\u00a0\u00a0<span style=\"box-sizing: border-box; color: #0077aa; vertical-align: baseline; border: 0px initial initial;\">pass<\/span><\/pre>\n<p style=\"box-sizing: border-box; color: #3e454c; margin-top: 1em; margin-bottom: 1.5em; vertical-align: baseline; word-break: break-word; line-height: 1.5; font-family: Nunito, sans-serif; font-size: 15.4px; text-align: start; white-space: normal; background-color: #ffffff; border: 0px initial initial;\"><span style=\"box-sizing: border-box; vertical-align: baseline; font-variant-numeric: normal; font-variant-east-asian: normal; line-height: 18px; color: #888888; border: 0px initial initial;\">\u6dfb\u52a0\u4e4b\u540e\u5237\u65b0\u9875\u9762\u4f60\u5c31\u4f1a\u770b\u5230\u5bfc\u5165\u548c\u5bfc\u51fa\u6309\u94ae\u3002<\/span><\/p>\n<p style=\"box-sizing: border-box; color: #3e454c; margin-top: 1em; margin-bottom: 1.5em; vertical-align: baseline; word-break: break-word; line-height: 1.5; font-family: Nunito, sans-serif; font-size: 15.4px; text-align: start; white-space: normal; background-color: #ffffff; border: 0px initial initial;\"><span style=\"box-sizing: border-box; color: #2e3033; vertical-align: baseline; font-variant-numeric: normal; font-variant-east-asian: normal; line-height: 18px; border: 0px initial initial;\"><img decoding=\"async\" loading=\"lazy\" style=\"box-sizing: border-box; color: inherit; vertical-align: baseline; margin-right: auto; margin-left: auto; height: 614px; display: block; width: 776px; border: 0px initial initial;\" title=\"Django\u6570\u636e\u5bfc\u5165\u5bfc\u51fa\u795e\u5668django-import-export\u4f7f\u7528\u6559\u7a0b\" src=\"http:\/\/www.zhushiyao.com\/wp-content\/uploads\/2021\/09\/2-1630681651.jpeg\" alt=\"Django\u6570\u636e\u5bfc\u5165\u5bfc\u51fa\u795e\u5668django-import-export\u4f7f\u7528\u6559\u7a0b\" width=\"776\" height=\"614\" \/><\/span><\/p>\n<p style=\"box-sizing: border-box; color: #3e454c; margin-top: 1em; margin-bottom: 1.5em; vertical-align: baseline; word-break: break-word; line-height: 1.5; font-family: Nunito, sans-serif; font-size: 15.4px; text-align: start; white-space: normal; background-color: #ffffff; border: 0px initial initial;\">\u5728\u5bfc\u5165\u73b0\u6709\u9879\u76ee\u65f6\uff0c\u5bfc\u5165\u529f\u80fd\u5177\u6709\u826f\u597d\u7684\u5dee\u5f02\u6027\uff1a<\/p>\n<p style=\"box-sizing: border-box; color: #3e454c; margin-top: 1em; margin-bottom: 1.5em; vertical-align: baseline; word-break: break-word; line-height: 1.5; font-family: Nunito, sans-serif; font-size: 15.4px; text-align: start; white-space: normal; background-color: #ffffff; border: 0px initial initial;\"><img decoding=\"async\" loading=\"lazy\" style=\"box-sizing: border-box; color: inherit; vertical-align: baseline; margin-right: auto; margin-left: auto; height: 535px; display: block; width: 775px; border: 0px initial initial;\" title=\"Django\u6570\u636e\u5bfc\u5165\u5bfc\u51fa\u795e\u5668django-import-export\u4f7f\u7528\u6559\u7a0b\" src=\"http:\/\/www.zhushiyao.com\/wp-content\/uploads\/2021\/09\/10-1630681651-1.jpeg\" alt=\"Django\u6570\u636e\u5bfc\u5165\u5bfc\u51fa\u795e\u5668django-import-export\u4f7f\u7528\u6559\u7a0b\" width=\"775\" height=\"535\" \/><\/p>\n<p style=\"box-sizing: border-box; color: #3e454c; margin-top: 1em; margin-bottom: 1.5em; vertical-align: baseline; word-break: break-word; line-height: 1.5; font-family: Nunito, sans-serif; font-size: 15.4px; text-align: start; white-space: normal; background-color: #ffffff; border: 0px initial initial;\"><span style=\"box-sizing: border-box; vertical-align: baseline; font-variant-numeric: normal; font-variant-east-asian: normal; line-height: 18px; color: #888888; border: 0px initial initial;\">\u8fd9\u662f\u4e00\u4e2a\u5f3a\u5927\u7684Django\u5e93\uff0c\u4f60\u53ef\u4ee5\u7528\u5b83\u505a\u66f4\u591a\u7684\u4e8b\u60c5\u3002\u6bd4\u5982\u53ea\u60f3\u6709\u5bfc\u51fa\u529f\u80fd\uff0c\u53ef\u4ee5\u4f7f\u7528ExportMixin\u3002<\/span><\/p>\n<section class=\"code-snippet__fix code-snippet__js\">\n<ul class=\"code-snippet__line-index code-snippet__js\">\n<li><\/li>\n<li><\/li>\n<li><\/li>\n<li><\/li>\n<li><\/li>\n<li><\/li>\n<li><\/li>\n<li><\/li>\n<\/ul>\n<pre class=\"code-snippet__js\"><code><span class=\"code-snippet_outer\"><span class=\"code-snippet__keyword\">from<\/span> .models <span class=\"code-snippet__keyword\">import<\/span> Person<\/span><\/code><code><span class=\"code-snippet_outer\"><span class=\"code-snippet__keyword\">from<\/span> django.contrib <span class=\"code-snippet__keyword\">import<\/span> admin<\/span><\/code><code><span class=\"code-snippet_outer\"><span class=\"code-snippet__keyword\">from<\/span> import_export.admin <span class=\"code-snippet__keyword\">import<\/span> ExportMixin<\/span><\/code><code><span class=\"code-snippet_outer\">\n<\/span><\/code><code><span class=\"code-snippet_outer\"><span class=\"code-snippet__class\"><span class=\"code-snippet__keyword\">class<\/span> <span class=\"code-snippet__title\">PersonAdmin<\/span><span class=\"code-snippet__params\">(ExportMixin, admin.ModelAdmin)<\/span>:<\/span><\/span><\/code><code><span class=\"code-snippet_outer\">    resource_class = PersonResource<\/span><\/code><code><span class=\"code-snippet_outer\">\n<\/span><\/code><code><span class=\"code-snippet_outer\">admin.site.register(Person, BookAdmin)<\/span><\/code><\/pre>\n<\/section>\n<p style=\"box-sizing: border-box; color: #3e454c; margin-top: 1em; margin-bottom: 1.5em; vertical-align: baseline; word-break: break-word; line-height: 1.5; font-family: Nunito, sans-serif; font-size: 15.4px; text-align: start; white-space: normal; background-color: #ffffff; border: 0px initial initial;\"><span style=\"color: #888888; font-family: Nunito, sans-serif; text-align: start; background-color: #ffffff; font-size: 15px;\">\u8be6\u7ec6\u6587\u6863\u5730\u5740\uff1a<\/span><span style=\"font-size: 15px;\"><strong style=\"font-family: Arial, sans-serif; font-size: 13px;\">https:\/\/django-import-export.readthedocs.io\/en\/latest\/<\/strong><\/span><\/p>\n<p style=\"box-sizing: border-box; color: #3e454c; margin-top: 1em; margin-bottom: 1.5em; vertical-align: baseline; word-break: break-word; line-height: 1.5; font-family: Nunito, sans-serif; font-size: 15.4px; text-align: start; white-space: normal; background-color: #ffffff; border: 0px initial initial;\"><span style=\"font-size: 14px; color: #888888;\">\u6587\u7ae0\u6765\u6e90\uff1aDjango\u4e2d\u6587\u7f51 \u4f5c\u8005\uff1a\u591c\u4e4b\u821e\u3002<\/span><\/p>\n<p style=\"box-sizing: border-box; color: #3e454c; margin-top: 1em; margin-bottom: 1.5em; vertical-align: baseline; word-break: break-word; line-height: 1.5; font-family: Nunito, sans-serif; font-size: 15.4px; text-align: start; white-space: normal; background-color: #ffffff; border: 0px initial initial;\">\n<\/div>\n","protected":false},"excerpt":{"rendered":"<p>\u987e\u540d\u601d\u4e49\uff0cdjango-import-export\u662f\u4e00\u4e2a\u7528\u4e8e\u5904\u7406\u5bfc\u5165\u548c\u5bfc\u51fa\u6570\u636e\u7684\u5e93\u3002\u5b83\u652f\u6301\u591a\u79cd\u683c\u5f0f\uff0c\u5305\u62ecxls &hellip; <a href=\"http:\/\/www.zhushiyao.com\/?p=86910\" class=\"more-link\">\u7ee7\u7eed\u9605\u8bfb<span class=\"screen-reader-text\">\u201cDjango\u6570\u636e\u5bfc\u5165\u5bfc\u51fa\u795e\u5668django-import-export\u4f7f\u7528\u6559\u7a0b\u201d<\/span><\/a><\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":[],"categories":[2],"tags":[883,8],"_links":{"self":[{"href":"http:\/\/www.zhushiyao.com\/index.php?rest_route=\/wp\/v2\/posts\/86910"}],"collection":[{"href":"http:\/\/www.zhushiyao.com\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"http:\/\/www.zhushiyao.com\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"http:\/\/www.zhushiyao.com\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"http:\/\/www.zhushiyao.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=86910"}],"version-history":[{"count":2,"href":"http:\/\/www.zhushiyao.com\/index.php?rest_route=\/wp\/v2\/posts\/86910\/revisions"}],"predecessor-version":[{"id":86917,"href":"http:\/\/www.zhushiyao.com\/index.php?rest_route=\/wp\/v2\/posts\/86910\/revisions\/86917"}],"wp:attachment":[{"href":"http:\/\/www.zhushiyao.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=86910"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"http:\/\/www.zhushiyao.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=86910"},{"taxonomy":"post_tag","embeddable":true,"href":"http:\/\/www.zhushiyao.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=86910"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}