{"id":16039,"date":"2024-01-20T02:28:14","date_gmt":"2024-01-19T22:58:14","guid":{"rendered":"https:\/\/rasanegar.com\/blog\/%d8%ae%d9%88%d8%a7%d9%86%d8%af%d9%86-%d9%88-%d9%86%d9%88%d8%b4%d8%aa%d9%86-%d9%81%d8%a7%db%8c%d9%84-%d9%87%d8%a7%db%8c-csv-%d8%af%d8%b1-node-js-%d8%a8%d8%a7-node-csv-%db%8c%da%a9-%da%a9%d8%a7%d8%b1\/"},"modified":"2024-01-20T02:28:14","modified_gmt":"2024-01-19T22:58:14","slug":"%d8%ae%d9%88%d8%a7%d9%86%d8%af%d9%86-%d9%88-%d9%86%d9%88%d8%b4%d8%aa%d9%86-%d9%81%d8%a7%db%8c%d9%84-%d9%87%d8%a7%db%8c-csv-%d8%af%d8%b1-node-js-%d8%a8%d8%a7-node-csv-%db%8c%da%a9-%da%a9%d8%a7%d8%b1","status":"publish","type":"post","link":"https:\/\/rasanegaar.com\/blog\/%d8%ae%d9%88%d8%a7%d9%86%d8%af%d9%86-%d9%88-%d9%86%d9%88%d8%b4%d8%aa%d9%86-%d9%81%d8%a7%db%8c%d9%84-%d9%87%d8%a7%db%8c-csv-%d8%af%d8%b1-node-js-%d8%a8%d8%a7-node-csv-%db%8c%da%a9-%da%a9%d8%a7%d8%b1\/","title":{"rendered":"\u062e\u0648\u0627\u0646\u062f\u0646 \u0648 \u0646\u0648\u0634\u062a\u0646 \u0641\u0627\u06cc\u0644 \u0647\u0627\u06cc CSV \u062f\u0631 Node.js \u0628\u0627 node-csv \u06cc\u06a9 \u06a9\u0627\u0631 \u0631\u0627\u06cc\u062c \u062a\u0648\u0633\u0639\u0647 \u062e\u0648\u0627\u0646\u062f\u0646 \u062f\u0627\u062f\u0647 \u0647\u0627 \u0627\u0632 \u0641\u0627\u06cc\u0644 \u0647\u0627 \u0627\u0633\u062a.  \u06cc\u06a9 \u0641\u0631\u0645\u062a \u0631\u0627\u06cc\u062c \u0641\u0627\u06cc\u0644\u060c \u0641\u0631\u0645\u062a csv. \u0627\u0633\u062a.  \u062f\u0631 \u062d\u0627\u0644\u06cc \u06a9\u0647 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u062f \u0641\u0627\u06cc\u0644\u200c\u0647\u0627\u06cc CSV \u0631\u0627 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0645\u0627\u0698\u0648\u0644 fs \u0647\u0645\u0631\u0627\u0647 \u0628\u0627 Node \u0628\u062e\u0648\u0627\u0646\u06cc\u062f \u0648 \u0645\u062d\u062a\u0648\u0627\u06cc \u0641\u0627\u06cc\u0644 \u0631\u0627 \u062f\u0631\u06cc\u0627\u0641\u062a \u06a9\u0646\u06cc\u062f\u060c \u062f\u0631 \u0628\u06cc\u0634\u062a\u0631 \u0645\u0648\u0627\u0631\u062f\u060c \u062a\u062c\u0632\u06cc\u0647 \u0648 \u062a\u0628\u062f\u06cc\u0644 \u0628\u06cc\u0634\u062a\u0631 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 &#8230;"},"content":{"rendered":"<div id=\"ez-toc-container\" class=\"ez-toc-v2_0_85 counter-hierarchy ez-toc-counter ez-toc-custom ez-toc-container-direction\">\n<div class=\"ez-toc-title-container\"><p class=\"ez-toc-title\" style=\"cursor:inherit\">\u0633\u0631\u0641\u0635\u0644\u0647\u0627\u06cc \u0645\u0637\u0644\u0628<\/p>\n<\/div><nav><ul class='ez-toc-list ez-toc-list-level-1 ' ><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-1\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%ae%d9%88%d8%a7%d9%86%d8%af%d9%86-%d9%88-%d9%86%d9%88%d8%b4%d8%aa%d9%86-%d9%81%d8%a7%db%8c%d9%84-%d9%87%d8%a7%db%8c-csv-%d8%af%d8%b1-node-js-%d8%a8%d8%a7-node-csv-%db%8c%da%a9-%da%a9%d8%a7%d8%b1\/#%d9%85%d8%b9%d8%b1%d9%81%db%8c\" >\u0645\u0639\u0631\u0641\u06cc<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-2\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%ae%d9%88%d8%a7%d9%86%d8%af%d9%86-%d9%88-%d9%86%d9%88%d8%b4%d8%aa%d9%86-%d9%81%d8%a7%db%8c%d9%84-%d9%87%d8%a7%db%8c-csv-%d8%af%d8%b1-node-js-%d8%a8%d8%a7-node-csv-%db%8c%da%a9-%da%a9%d8%a7%d8%b1\/#%d8%af%d8%b1_%d8%ad%d8%a7%d9%84_%d9%86%d8%b5%d8%a8_node-csv\" >\u062f\u0631 \u062d\u0627\u0644 \u0646\u0635\u0628 node-csv<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-3\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%ae%d9%88%d8%a7%d9%86%d8%af%d9%86-%d9%88-%d9%86%d9%88%d8%b4%d8%aa%d9%86-%d9%81%d8%a7%db%8c%d9%84-%d9%87%d8%a7%db%8c-csv-%d8%af%d8%b1-node-js-%d8%a8%d8%a7-node-csv-%db%8c%da%a9-%da%a9%d8%a7%d8%b1\/#%d8%ae%d9%88%d8%a7%d9%86%d8%af%d9%86_%d9%81%d8%a7%db%8c%d9%84%e2%80%8c%d9%87%d8%a7%db%8c_csv_%d8%a8%d8%a7_csv-parse\" >\u062e\u0648\u0627\u0646\u062f\u0646 \u0641\u0627\u06cc\u0644\u200c\u0647\u0627\u06cc CSV \u0628\u0627 CSV-Parse<\/a><ul class='ez-toc-list-level-3' ><li class='ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-4\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%ae%d9%88%d8%a7%d9%86%d8%af%d9%86-%d9%88-%d9%86%d9%88%d8%b4%d8%aa%d9%86-%d9%81%d8%a7%db%8c%d9%84-%d9%87%d8%a7%db%8c-csv-%d8%af%d8%b1-node-js-%d8%a8%d8%a7-node-csv-%db%8c%da%a9-%da%a9%d8%a7%d8%b1\/#stream_callback_api\" >Stream + Callback API<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-5\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%ae%d9%88%d8%a7%d9%86%d8%af%d9%86-%d9%88-%d9%86%d9%88%d8%b4%d8%aa%d9%86-%d9%81%d8%a7%db%8c%d9%84-%d9%87%d8%a7%db%8c-csv-%d8%af%d8%b1-node-js-%d8%a8%d8%a7-node-csv-%db%8c%da%a9-%da%a9%d8%a7%d8%b1\/#%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87_%d8%a7%d8%b2_sync_api\" >\u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 Sync API<\/a><\/li><\/ul><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-6\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%ae%d9%88%d8%a7%d9%86%d8%af%d9%86-%d9%88-%d9%86%d9%88%d8%b4%d8%aa%d9%86-%d9%81%d8%a7%db%8c%d9%84-%d9%87%d8%a7%db%8c-csv-%d8%af%d8%b1-node-js-%d8%a8%d8%a7-node-csv-%db%8c%da%a9-%da%a9%d8%a7%d8%b1\/#%d9%86%d9%88%d8%b4%d8%aa%d9%86_%d9%81%d8%a7%db%8c%d9%84%e2%80%8c%d9%87%d8%a7%db%8c_csv_%d8%a8%d8%a7_%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87_%d8%a7%d8%b2_csv_stringify\" >\u0646\u0648\u0634\u062a\u0646 \u0641\u0627\u06cc\u0644\u200c\u0647\u0627\u06cc CSV \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 CSV Stringify<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-7\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%ae%d9%88%d8%a7%d9%86%d8%af%d9%86-%d9%88-%d9%86%d9%88%d8%b4%d8%aa%d9%86-%d9%81%d8%a7%db%8c%d9%84-%d9%87%d8%a7%db%8c-csv-%d8%af%d8%b1-node-js-%d8%a8%d8%a7-node-csv-%db%8c%da%a9-%da%a9%d8%a7%d8%b1\/#%d9%86%d8%aa%db%8c%d8%ac%d9%87\" >\u0646\u062a\u06cc\u062c\u0647<\/a><\/li><\/ul><\/nav><\/div>\n<span class=\"span-reading-time rt-reading-time\" style=\"display: block;\"><span class=\"rt-label rt-prefix\">\u0632\u0645\u0627\u0646 \u0644\u0627\u0632\u0645 \u0628\u0631\u0627\u06cc \u0645\u0637\u0627\u0644\u0639\u0647: <\/span> <span class=\"rt-time\"> 5<\/span> <span class=\"rt-label rt-postfix\">\u062f\u0642\u06cc\u0642\u0647<\/span><\/span><p> <br \/>\n<\/p>\n<div class=\"content\"><noscript><\/p>\n<style>.lazyload-placeholder { display: none;  }<\/style>\n<p><\/noscript><\/p>\n<h2 id=\"introduction\"><span class=\"ez-toc-section\" id=\"%d9%85%d8%b9%d8%b1%d9%81%db%8c\"><\/span>\u0645\u0639\u0631\u0641\u06cc<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u06cc\u06a9 \u06a9\u0627\u0631 \u062a\u0648\u0633\u0639\u0647 \u0631\u0627\u06cc\u062c \u062e\u0648\u0627\u0646\u062f\u0646 \u062f\u0627\u062f\u0647 \u0647\u0627 \u0627\u0632 \u0641\u0627\u06cc\u0644 \u0647\u0627 \u0627\u0633\u062a.  \u06cc\u06a9 \u0641\u0631\u0645\u062a \u0641\u0627\u06cc\u0644 \u0631\u0627\u06cc\u062c \u0627\u0633\u062a <code>.csv<\/code> \u0642\u0627\u0644\u0628<\/p>\n<p>\u062f\u0631 \u062d\u0627\u0644\u06cc \u06a9\u0647 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0641\u0627\u06cc\u0644 \u0647\u0627\u06cc CSV \u0631\u0627 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 <code>fs<\/code> \u0645\u0627\u0698\u0648\u0644\u06cc \u06a9\u0647 \u0628\u0627 Node \u0627\u0631\u0627\u0626\u0647 \u0645\u06cc \u0634\u0648\u062f \u0648 \u0645\u062d\u062a\u0648\u0627\u06cc \u0641\u0627\u06cc\u0644 \u0631\u0627 \u062f\u0631\u06cc\u0627\u0641\u062a \u0645\u06cc \u06a9\u0646\u062f\u060c \u062f\u0631 \u0628\u06cc\u0634\u062a\u0631 \u0645\u0648\u0627\u0631\u062f\u060c \u062a\u062c\u0632\u06cc\u0647 \u0648 \u062a\u0628\u062f\u06cc\u0644 \u0628\u06cc\u0634\u062a\u0631 \u0628\u0627 \u06a9\u0645\u06a9 \u0645\u0627\u0698\u0648\u0644 \u0647\u0627\u06cc\u06cc \u06a9\u0647 \u062f\u0642\u06cc\u0642\u0627\u064b \u0628\u0631\u0627\u06cc \u0627\u06cc\u0646 \u0645\u0646\u0638\u0648\u0631 \u0633\u0627\u062e\u062a\u0647 \u0634\u062f\u0647 \u0627\u0646\u062f \u0628\u0633\u06cc\u0627\u0631 \u0622\u0633\u0627\u0646 \u062a\u0631 \u0627\u0633\u062a.<\/p>\n<p>\u0645\u0627\u0698\u0648\u0644 \u0647\u0627\u06cc \u0645\u062a\u0639\u062f\u062f \u0686\u0646\u06cc\u0646 \u0642\u0627\u0628\u0644\u06cc\u062a \u0647\u0627\u06cc\u06cc \u0645\u0627\u0646\u0646\u062f <code>neat-csv<\/code> \u06cc\u0627 <code>csv-parser<\/code> \u0628\u0633\u062a\u0647 \u0647\u0627  \u0628\u0627 \u0627\u06cc\u0646 \u062d\u0627\u0644\u060c \u062f\u0631 \u0627\u06cc\u0646 \u0645\u0642\u0627\u0644\u0647\u060c \u0645\u0627 \u0627\u0632 \u0622\u0646 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u062e\u0648\u0627\u0647\u06cc\u0645 \u06a9\u0631\u062f <a href=\"https:\/\/csv.js.org\/\" rel=\"nofollow noopener\" target=\"_blank\"><code>node-csv<\/code><\/a>  &#8211; \u0645\u062c\u0645\u0648\u0639\u0647 \u0627\u06cc \u0627\u0632 \u0628\u0633\u062a\u0647 \u0647\u0627\u06cc CSV \u0628\u0631\u0627\u06cc \u062a\u0648\u0644\u06cc\u062f\u060c \u062a\u062c\u0632\u06cc\u0647\u060c \u062a\u0628\u062f\u06cc\u0644 \u0648 \u0631\u0634\u062a\u0647 \u0633\u0627\u0632\u06cc \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc CSV.<\/p>\n<h2 id=\"installingnodecsv\"><span class=\"ez-toc-section\" id=\"%d8%af%d8%b1_%d8%ad%d8%a7%d9%84_%d9%86%d8%b5%d8%a8_node-csv\"><\/span>\u062f\u0631 \u062d\u0627\u0644 \u0646\u0635\u0628 <em>node-csv<\/em><span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0645\u0627\u0698\u0648\u0644 \u0634\u0627\u0645\u0644 <code>csv-generate<\/code>\u060c <code>csv-parse<\/code>\u060c <code>csv-transform<\/code> \u0648 <code>csv-stringify<\/code> \u0628\u0633\u062a\u0647 \u0647\u0627<\/p>\n<p>\u0627\u06af\u0631 \u0628\u0647 \u0647\u0645\u0647 \u0622\u0646\u0647\u0627 \u0646\u06cc\u0627\u0632 \u0646\u062f\u0627\u0631\u06cc\u062f\u060c \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u06a9\u0644 \u0645\u062c\u0645\u0648\u0639\u0647 \u06cc\u0627 \u0647\u0631 \u0628\u0633\u062a\u0647 \u0631\u0627 \u06cc\u06a9\u06cc \u06cc\u06a9\u06cc \u0646\u0635\u0628 \u06a9\u0646\u06cc\u062f.  \u0628\u06cc\u0627\u06cc\u06cc\u062f \u06cc\u06a9 \u067e\u0631\u0648\u0698\u0647 Node \u0631\u0627 \u0628\u0627 \u062a\u0646\u0638\u06cc\u0645\u0627\u062a \u067e\u06cc\u0634 \u0641\u0631\u0636 \u0645\u0642\u062f\u0627\u0631\u062f\u0647\u06cc \u06a9\u0646\u06cc\u0645:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-meta\">$<\/span><span class=\"bash\"> npm init -y<\/span>\n<\/code><\/pre>\n<p>\u0633\u067e\u0633\u060c \u0628\u06cc\u0627\u06cc\u06cc\u062f \u06a9\u0644 \u0631\u0627 \u0646\u0635\u0628 \u06a9\u0646\u06cc\u0645 <code>node-csv<\/code> \u0633\u0648\u0626\u06cc\u062a:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-meta\">$<\/span><span class=\"bash\"> npm install csv<\/span>\n<\/code><\/pre>\n<div class=\"alert alert-note\">\n<div class=\"flex\">\n<div class=\"flex-shrink-0 mr-3\"><\/div>\n<div class=\"w-full\">\n<p><strong>\u062a\u0648\u062c\u0647 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u06cc\u062f:<\/strong> \u0627\u06af\u0631\u0686\u0647 \u0633\u0648\u0626\u06cc\u062a \u0646\u0627\u0645\u06cc\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f <code>node-csv<\/code> &#8211; \u0628\u0633\u062a\u0647 NPM \u0645\u0631\u0628\u0648\u0637\u0647 \u062f\u0631 \u0648\u0627\u0642\u0639 \u0641\u0631\u0627\u062e\u0648\u0627\u0646\u06cc \u0645\u06cc \u0634\u0648\u062f <code>csv<\/code>.<\/p>\n<\/p><\/div><\/div><\/div>\n<p>\u0645\u0627 \u0628\u0627 \u06cc\u06a9 \u0641\u0627\u06cc\u0644 CSV \u0628\u0627 \u0627\u06cc\u0646 \u0645\u062d\u062a\u0648\u06cc\u0627\u062a \u06a9\u0627\u0631 \u062e\u0648\u0627\u0647\u06cc\u0645 \u06a9\u0631\u062f:<\/p>\n<pre><code class=\"hljs\">Account Name,Account Code,Type,Description\nCash,101,Assets,Checking account balance\nWages Payable,220,Liabilities,Amount owed to employee for hours not yet paid\nRent expense,560,Expenses,Cost of occupied rented facilities during accounting period\n<\/code><\/pre>\n<h2 id=\"readingcsvfileswithcsvparse\"><span class=\"ez-toc-section\" id=\"%d8%ae%d9%88%d8%a7%d9%86%d8%af%d9%86_%d9%81%d8%a7%db%8c%d9%84%e2%80%8c%d9%87%d8%a7%db%8c_csv_%d8%a8%d8%a7_csv-parse\"><\/span>\u062e\u0648\u0627\u0646\u062f\u0646 \u0641\u0627\u06cc\u0644\u200c\u0647\u0627\u06cc CSV \u0628\u0627 CSV-Parse<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0628\u0631\u0627\u06cc \u062e\u0648\u0627\u0646\u062f\u0646 \u0641\u0627\u06cc\u0644\u200c\u0647\u0627\u06cc CSV\u060c \u0627\u0632 \u0622\u0646 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc\u200c\u06a9\u0646\u06cc\u0645 <a href=\"https:\/\/csv.js.org\/parse\/\" rel=\"nofollow noopener\" target=\"_blank\"><code>csv-parse<\/code><\/a>  \u0628\u0633\u062a\u0647 \u0627\u0632 <code>node-csv<\/code>.<\/p>\n<p>\u0631\u0627 <code>csv-parse<\/code> \u0628\u0633\u062a\u0647 \u0631\u0648\u06cc\u06a9\u0631\u062f\u0647\u0627\u06cc \u0645\u062a\u0639\u062f\u062f\u06cc \u0631\u0627 \u0628\u0631\u0627\u06cc \u062a\u062c\u0632\u06cc\u0647 \u0641\u0627\u06cc\u0644\u200c\u0647\u0627\u06cc CSV \u0627\u0631\u0627\u0626\u0647 \u0645\u06cc\u200c\u06a9\u0646\u062f &#8211; \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 callbacks\u060c \u062c\u0631\u06cc\u0627\u0646 + callback \u0648 \u0647\u0645\u0686\u0646\u06cc\u0646 Sync \u0648 Async API.  \u0645\u0627 \u0631\u0627 \u067e\u0648\u0634\u0634 \u062e\u0648\u0627\u0647\u06cc\u0645 \u062f\u0627\u062f <em>stream + callback API<\/em> \u0648 <em>\u0647\u0645\u06af\u0627\u0645 \u0633\u0627\u0632\u06cc API<\/em>.<\/p>\n<h3 id=\"streamcallbackapi\"><span class=\"ez-toc-section\" id=\"stream_callback_api\"><\/span>Stream + Callback API<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u0628\u06cc\u0627\u06cc\u06cc\u062f \u06cc\u06a9 \u0641\u0627\u06cc\u0644 \u0628\u0647 \u0646\u0627\u0645 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u0645 <code>index.js<\/code> \u0648 a \u0631\u0627 \u0628\u0633\u0627\u0632\u06cc\u062f <code>parser<\/code>:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">var<\/span> fs = <span class=\"hljs-built_in\">require<\/span>(<span class=\"hljs-string\">'fs'<\/span>); \n<span class=\"hljs-keyword\">var<\/span> parse = <span class=\"hljs-built_in\">require<\/span>(<span class=\"hljs-string\">'csv-parse'<\/span>);\n<span class=\"hljs-keyword\">var<\/span> parser = parse({<span class=\"hljs-attr\">columns<\/span>: <span class=\"hljs-literal\">true<\/span>}, <span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span> (<span class=\"hljs-params\">err, records<\/span>) <\/span>{\n    <span class=\"hljs-built_in\">console<\/span>.log(records);\n});\n\nfs.createReadStream(__dirname+<span class=\"hljs-string\">'\/chart-of-accounts.csv'<\/span>).pipe(parser);\n<\/code><\/pre>\n<p>\u0627\u0648\u0644 \u0645\u0627 import \u0645\u0627\u0698\u0648\u0644 \u0633\u06cc\u0633\u062a\u0645 \u0641\u0627\u06cc\u0644 \u0628\u0648\u0645\u06cc (<code>fs<\/code>) \u0648 <code>csv-parse<\/code> \u0645\u062f\u0648\u0644.  \u0633\u067e\u0633\u060c \u06cc\u06a9 \u0631\u0627 \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc \u06a9\u0646\u06cc\u0645 <code>parser<\/code> \u06a9\u0647 \u06cc\u06a9 \u0634\u06cc \u0631\u0627 \u0628\u0647 \u0635\u0648\u0631\u062a \u062a\u062d\u062a \u0627\u0644\u0644\u0641\u0638\u06cc \u0645\u06cc \u067e\u0630\u06cc\u0631\u062f \u06a9\u0647 \u0634\u0627\u0645\u0644 \u06af\u0632\u06cc\u0646\u0647 \u0647\u0627\u06cc\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0645\u06cc \u062e\u0648\u0627\u0647\u06cc\u0645 \u062a\u0646\u0638\u06cc\u0645 \u06a9\u0646\u06cc\u0645.  \u0622\u0631\u06af\u0648\u0645\u0627\u0646 \u062f\u0648\u0645 \u062a\u0627\u0628\u0639 callback \u0627\u0633\u062a \u06a9\u0647 \u0628\u0631\u0627\u06cc \u062f\u0633\u062a\u0631\u0633\u06cc \u0628\u0647 \u0631\u06a9\u0648\u0631\u062f\u0647\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f &#8211; \u06cc\u0627 \u0641\u0642\u0637 print \u062f\u0631 \u0645\u0648\u0631\u062f \u0645\u0627 \u0622\u0646\u0647\u0627 \u0631\u0627 \u0628\u06cc\u0631\u0648\u0646 \u0628\u06cc\u0627\u0648\u0631\u0646\u062f.<\/p>\n<p>\u06af\u0632\u06cc\u0646\u0647 \u0647\u0627\u06cc\u06cc \u06a9\u0647 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u0645 \u062a\u0646\u0638\u06cc\u0645 \u06a9\u0646\u06cc\u0645 \u0627\u062c\u0628\u0627\u0631\u06cc \u0646\u06cc\u0633\u062a\u0646\u062f.  \u062f\u0631 \u0628\u06cc\u0634\u062a\u0631 \u0645\u0648\u0627\u0631\u062f\u060c \u0634\u0645\u0627 \u0627\u0632 \u0647\u0631 \u06cc\u06a9 \u0627\u0632 \u0622\u0646\u0647\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u062e\u0648\u0627\u0647\u06cc\u062f \u06a9\u0631\u062f <code>delimiter<\/code>\u060c <code>cast<\/code> \u06cc\u0627 <code>columns<\/code> \u06af\u0632\u06cc\u0646\u0647 \u0647\u0627:<\/p>\n<ul>\n<li>\n<p>\u0631\u0627 <em><strong>\u062d\u0627\u0626\u0644\u060c \u062c\u062f\u0627\u06a9\u0646\u0646\u062f\u0647<\/strong><\/em>  \u06af\u0632\u06cc\u0646\u0647 \u067e\u06cc\u0634\u200c\u0641\u0631\u0636 \u06a9\u0627\u0645\u0627 \u0627\u0633\u062a <code>,<\/code>.  \u0627\u06af\u0631 \u062f\u0627\u062f\u0647\u200c\u0647\u0627\u06cc \u0641\u0627\u06cc\u0644\u06cc \u06a9\u0647 \u0645\u06cc\u200c\u062e\u0648\u0627\u0647\u06cc\u062f \u062a\u062c\u0632\u06cc\u0647 \u06a9\u0646\u06cc\u062f\u060c \u0627\u0632 \u062c\u062f\u0627\u06a9\u0646\u0646\u062f\u0647 \u062f\u06cc\u06af\u0631\u06cc \u0645\u0627\u0646\u0646\u062f \u0646\u06cc\u0645\u200c\u06a9\u0648\u0644\u0648\u0646 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc\u200c\u06a9\u0646\u062f <code>;<\/code>\u060c \u06cc\u0627 \u06cc\u06a9 \u0644\u0648\u0644\u0647 <code>|<\/code>\u060c \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0628\u0627 \u0627\u06cc\u0646 \u06af\u0632\u06cc\u0646\u0647 \u0645\u0634\u062e\u0635 \u06a9\u0646\u06cc\u062f.<\/p>\n<\/li>\n<li>\n<p>\u0631\u0627 <em><strong>\u0642\u0627\u0644\u0628<\/strong><\/em>  \u06af\u0632\u06cc\u0646\u0647 \u067e\u06cc\u0634 \u0641\u0631\u0636 \u0628\u0647 <code>false<\/code> \u0648 \u0628\u0631\u0627\u06cc \u0646\u0634\u0627\u0646 \u062f\u0627\u062f\u0646 \u0627\u06cc\u0646\u06a9\u0647 \u0622\u06cc\u0627 \u0645\u06cc\u200c\u062e\u0648\u0627\u0647\u06cc\u062f \u0631\u0634\u062a\u0647\u200c\u0647\u0627 \u0631\u0627 \u0628\u0647 \u0627\u0646\u0648\u0627\u0639 \u062f\u0627\u062f\u0647\u200c\u0647\u0627\u06cc \u0627\u0635\u0644\u06cc \u0622\u0646\u200c\u0647\u0627 \u0627\u0631\u0633\u0627\u0644 \u06a9\u0646\u06cc\u062f \u06cc\u0627 \u062e\u06cc\u0631 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc\u200c\u0634\u0648\u062f.  \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0645\u062b\u0627\u0644\u060c \u0633\u062a\u0648\u0646\u06cc \u06a9\u0647 \u0627\u0632 \u0641\u06cc\u0644\u062f\u0647\u0627\u06cc \u062a\u0627\u0631\u06cc\u062e \u062a\u0634\u06a9\u06cc\u0644 \u0634\u062f\u0647 \u0627\u0633\u062a \u0631\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646 \u0628\u0647 a \u0631\u06cc\u062e\u062a <code>Date<\/code>.<\/p>\n<\/li>\n<li>\n<p>\u0631\u0627 <em><strong>\u0633\u062a\u0648\u0646 \u0647\u0627<\/strong><\/em>  \u06af\u0632\u06cc\u0646\u0647 \u0627\u06cc\u0646 \u0627\u0633\u062a \u06a9\u0647 \u0646\u0634\u0627\u0646 \u062f\u0647\u062f \u0622\u06cc\u0627 \u0645\u06cc \u062e\u0648\u0627\u0647\u06cc\u062f \u0631\u06a9\u0648\u0631\u062f \u0631\u0627 \u0628\u0647 \u0634\u06a9\u0644 \u0644\u0641\u0638 \u0634\u06cc\u0621 \u062a\u0648\u0644\u06cc\u062f \u06a9\u0646\u06cc\u062f \u06cc\u0627 \u062e\u06cc\u0631.  \u0628\u0647 \u0637\u0648\u0631 \u067e\u06cc\u0634 \u0641\u0631\u0636\u060c \u0627\u06cc\u0646 \u0633\u062a\u0648\u0646 \u0631\u0648\u06cc \u062a\u0646\u0638\u06cc\u0645 \u0634\u062f\u0647 \u0627\u0633\u062a <code>false<\/code> \u0648 \u0631\u06a9\u0648\u0631\u062f\u0647\u0627 \u062a\u0648\u0633\u0637 \u062a\u062c\u0632\u06cc\u0647 \u06a9\u0646\u0646\u062f\u0647 \u0628\u0647 \u0634\u06a9\u0644 \u0622\u0631\u0627\u06cc\u0647 \u062a\u0648\u0644\u06cc\u062f \u0645\u06cc \u0634\u0648\u0646\u062f.  \u0627\u06af\u0631 \u062a\u0646\u0638\u06cc\u0645 \u0634\u0648\u062f <code>true<\/code>\u060c \u062a\u062c\u0632\u06cc\u0647 \u06a9\u0646\u0646\u062f\u0647 \u0646\u0627\u0645 \u0633\u062a\u0648\u0646 \u0631\u0627 \u0627\u0632 \u062e\u0637 \u0627\u0648\u0644 \u0627\u0633\u062a\u0646\u062a\u0627\u062c \u0645\u06cc \u06a9\u0646\u062f.<\/p>\n<\/li>\n<\/ul>\n<p>\u062f\u0631 \u0646\u0647\u0627\u06cc\u062a\u060c \u0645\u0627 \u06cc\u06a9 \u062c\u0631\u06cc\u0627\u0646 \u062e\u0648\u0627\u0646\u062f\u0646\u06cc \u0631\u0627 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0622\u0646 \u0628\u0627\u0632 \u06a9\u0631\u062f\u06cc\u0645 <code>fs<\/code> \u0645\u0627\u0698\u0648\u0644 \u0648 \u0634\u0631\u0648\u0639 \u0628\u0647 \u0644\u0648\u0644\u0647 \u06af\u0630\u0627\u0631\u06cc \u0622\u0646 \u0628\u0647 \u062a\u062c\u0632\u06cc\u0647 \u06a9\u0646\u0646\u062f\u0647 \u06a9\u0631\u062f.<\/p>\n<p>\u0628\u06cc\u0627\u06cc\u06cc\u062f \u0627\u06cc\u0646 \u0641\u0627\u06cc\u0644 \u0631\u0627 \u0627\u062c\u0631\u0627 \u06a9\u0646\u06cc\u0645:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-meta\">$<\/span><span class=\"bash\"> node index.js<\/span>\n<\/code><\/pre>\n<p>\u0627\u06cc\u0646 \u0646\u062a\u06cc\u062c\u0647 \u062f\u0631:<\/p>\n<pre><code class=\"hljs\">(\n  {\n    'Account Name': 'Cash',\n    'Account Code': '101',\n    Type: 'Assets',\n    Description: 'Checking account balance'\n  },\n  {\n    'Account Name': 'Wages Payable',\n    'Account Code': '220',\n    Type: 'Liabilities',\n    Description: 'Amount owed to employee for hours not yet paid'\n  },\n  {\n    'Account Name': 'Rent expense',\n    'Account Code': '560',\n    Type: 'Expenses',\n    Description: 'Cost of occupied rented facilities during accounting period'\n  }\n)\n<\/code><\/pre>\n<p>\u0628\u0647 \u062c\u0627\u06cc \u0627\u06cc\u0646\u06a9\u0647 \u0641\u0642\u0637 \u0645\u062d\u062a\u0648\u06cc\u0627\u062a \u0631\u0627 \u0686\u0627\u067e \u06a9\u0646\u06cc\u062f\u060c \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0627\u06cc\u0646 \u062f\u0627\u062f\u0647 \u0647\u0627 \u0631\u0627 \u062f\u0633\u062a\u06a9\u0627\u0631\u06cc \u06a9\u0646\u06cc\u062f\u060c \u0627\u0634\u06cc\u0627\u0621 \u0631\u0627 \u0628\u0627 \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0627\u06cc\u0646 \u0641\u06cc\u0644\u062f\u0647\u0627 \u0628\u0633\u0627\u0632\u06cc\u062f \u06cc\u0627 \u0622\u0646\u0647\u0627 \u0631\u0627 \u062f\u0631 \u06cc\u06a9 \u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647 \u0630\u062e\u06cc\u0631\u0647 \u06a9\u0646\u06cc\u062f.<\/p>\n<h3 id=\"usingsyncapi\"><span class=\"ez-toc-section\" id=\"%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87_%d8%a7%d8%b2_sync_api\"><\/span>\u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 Sync API<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u0628\u06cc\u0627\u06cc\u06cc\u062f \u0627\u06cc\u0646 \u0639\u0645\u0644\u06a9\u0631\u062f \u0631\u0627 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 Sync API \u062a\u06a9\u0631\u0627\u0631 \u06a9\u0646\u06cc\u0645:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">var<\/span> fs = <span class=\"hljs-built_in\">require<\/span>(<span class=\"hljs-string\">'fs'<\/span>).promises;\n<span class=\"hljs-keyword\">var<\/span> parse = <span class=\"hljs-built_in\">require<\/span>(<span class=\"hljs-string\">'csv-parse\/lib\/sync'<\/span>);\n(<span class=\"hljs-keyword\">async<\/span> <span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span> (<span class=\"hljs-params\"><\/span>) <\/span>{\n    <span class=\"hljs-keyword\">const<\/span> fileContent = <span class=\"hljs-keyword\">await<\/span> fs.readFile(__dirname+<span class=\"hljs-string\">'\/chart-of-accounts.csv'<\/span>);\n    <span class=\"hljs-keyword\">const<\/span> records = parse(fileContent, {<span class=\"hljs-attr\">columns<\/span>: <span class=\"hljs-literal\">true<\/span>});\n    <span class=\"hljs-built_in\">console<\/span>.log(records)\n})();\n<\/code><\/pre>\n<p>\u062f\u0648\u0628\u0627\u0631\u0647\u060c \u0645\u0627 \u062f\u0631 \u062d\u0627\u0644 \u0648\u0627\u0631\u062f\u0627\u062a \u0647\u0633\u062a\u06cc\u0645 <code>fs<\/code> \u0645\u0627\u0698\u0648\u0644 \u0648 Sync API \u0627\u0632 <code>csv-parse<\/code> \u0645\u062f\u0648\u0644.<\/p>\n<p>\u0633\u067e\u0633\u060c \u0645\u0627 \u062f\u0631 \u062d\u0627\u0644 \u0627\u06cc\u062c\u0627\u062f \u06cc\u06a9 <code>async<\/code> \u062a\u0627\u0628\u0639\u060c \u06a9\u0647 \u062f\u0631 \u0622\u0646 \u0645\u062d\u062a\u0648\u06cc\u0627\u062a \u0641\u0627\u06cc\u0644 \u0631\u0627 \u062a\u0648\u0633\u0637 <code>await<\/code>\u062f\u0631 \u067e\u0627\u0633\u062e \u0628\u0647 <code>readFile()<\/code> \u062a\u0627\u0628\u0639.<\/p>\n<p>\u0633\u067e\u0633\u060c \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u0645 a \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u0645 <code>parser<\/code> \u06a9\u0647 \u0645\u062d\u062a\u0648\u06cc\u0627\u062a \u0641\u0627\u06cc\u0644 \u0631\u0627 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0622\u0631\u06af\u0648\u0645\u0627\u0646 \u0627\u0648\u0644 \u0648 \u06cc\u06a9 \u0634\u06cc \u0631\u0627 \u0628\u0647 \u0645\u0639\u0646\u0627\u06cc \u0648\u0627\u0642\u0639\u06cc \u06a9\u0644\u0645\u0647 \u062f\u0648\u0645 \u0645\u06cc \u06af\u06cc\u0631\u062f.  \u0627\u06cc\u0646 \u0634\u06cc \u0644\u0641\u0638\u06cc \u0634\u0627\u0645\u0644 \u06af\u0632\u06cc\u0646\u0647 \u0647\u0627\u06cc\u06cc \u0628\u0631\u0627\u06cc \u0627\u06cc\u062c\u0627\u062f \u062a\u062c\u0632\u06cc\u0647 \u06a9\u0646\u0646\u062f\u0647 \u0627\u0633\u062a (\u0645\u0627 \u062a\u0646\u0638\u06cc\u0645 \u06a9\u0631\u062f\u0647 \u0627\u06cc\u0645 <code>columns<\/code> \u0628\u0647 <code>true<\/code>).  \u0627\u06cc\u0646 \u062a\u062c\u0632\u06cc\u0647 \u06a9\u0646\u0646\u062f\u0647 \u0628\u0647 \u06cc\u06a9 \u0645\u062a\u063a\u06cc\u0631 \u062b\u0627\u0628\u062a \u0627\u062e\u062a\u0635\u0627\u0635 \u062f\u0627\u062f\u0647 \u0634\u062f\u0647 \u0627\u0633\u062a \u0648 \u0645\u0627 \u0628\u0647 \u0633\u0627\u062f\u06af\u06cc print \u0645\u0637\u0627\u0644\u0628 \u0622\u0646 \u0628\u0631\u0627\u06cc \u0627\u062e\u062a\u0635\u0627\u0631 \u0628\u06cc\u0627\u0646 \u0645\u06cc \u0634\u0648\u062f:<\/p>\n<pre><code class=\"hljs\">(\n  {\n    'Account Name': 'Cash',\n    'Account Code': '101',\n    Type: 'Assets',\n    Description: 'Checking account balance'\n  },\n  {\n    'Account Name': 'Wages Payable',\n    'Account Code': '220',\n    Type: 'Liabilities',\n    Description: 'Amount owed to employee for hours not yet paid'\n  },\n  {\n    'Account Name': 'Rent expense',\n    'Account Code': '560',\n    Type: 'Expenses',\n    Description: 'Cost of occupied rented facilities during accounting period'\n  }\n)\n<\/code><\/pre>\n<h2 id=\"writingcsvfilesusingcsvstringify\"><span class=\"ez-toc-section\" id=\"%d9%86%d9%88%d8%b4%d8%aa%d9%86_%d9%81%d8%a7%db%8c%d9%84%e2%80%8c%d9%87%d8%a7%db%8c_csv_%d8%a8%d8%a7_%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87_%d8%a7%d8%b2_csv_stringify\"><\/span>\u0646\u0648\u0634\u062a\u0646 \u0641\u0627\u06cc\u0644\u200c\u0647\u0627\u06cc CSV \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 CSV Stringify<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0634\u0628\u06cc\u0647 \u0628\u0647 \u062e\u0648\u0627\u0646\u062f\u0646\u060c \u0645\u0627 \u06af\u0627\u0647\u06cc \u0627\u0648\u0642\u0627\u062a \u062f\u0648\u0633\u062a \u062f\u0627\u0631\u06cc\u0645 <em>\u0646\u0648\u0634\u062a\u0646<\/em> \u062f\u0627\u062f\u0647 \u0647\u0627 \u0631\u0627 \u0628\u0647 \u0641\u0631\u0645\u062a CSV \u062a\u0628\u062f\u06cc\u0644 \u06a9\u0646\u06cc\u062f.  \u0628\u0631\u0627\u06cc \u0627\u06cc\u0646\u060c \u0645\u0627 \u0627\u0632 <a href=\"https:\/\/csv.js.org\/stringify\/\" rel=\"nofollow noopener\" target=\"_blank\"><code>csv-stringify<\/code><\/a>  \u0628\u0633\u062a\u0647 \u0627\u0632 <code>node-csv<\/code> \u0633\u0648\u0626\u06cc\u062a <em>\u0631\u0634\u062a\u0647 \u0628\u0646\u062f\u06cc<\/em> \u0641\u0642\u0637 \u0628\u0647 \u0627\u06cc\u0646 \u0645\u0639\u0646\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0645\u0627 \u0628\u0631\u062e\u06cc \u0627\u0632 \u062f\u0627\u062f\u0647 \u0647\u0627 (\u062f\u0631 \u0645\u062b\u0627\u0644 \u0645\u0627 JSON) \u0631\u0627 \u0628\u0647 \u06cc\u06a9 \u0631\u0634\u062a\u0647 \u062a\u0628\u062f\u06cc\u0644 \u0645\u06cc \u06a9\u0646\u06cc\u0645.  \u0633\u067e\u0633 \u0627\u06cc\u0646 \u0631\u0634\u062a\u0647 \u062f\u0631 \u06cc\u06a9 \u0641\u0627\u06cc\u0644 \u0628\u0627 \u0641\u0631\u0645\u062a CSV \u0646\u0648\u0634\u062a\u0647 \u0645\u06cc \u0634\u0648\u062f.<\/p>\n<p>\u0628\u06cc\u0627\u06cc\u06cc\u062f \u0641\u0631\u0636 \u06a9\u0646\u06cc\u0645 \u0628\u0631\u062e\u06cc \u0627\u0632 \u0645\u062d\u062a\u0648\u06cc\u0627\u062a JSON \u0631\u0627 \u062f\u0627\u0631\u06cc\u062f \u06a9\u0647 \u0645\u06cc \u062e\u0648\u0627\u0647\u06cc\u062f \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u06cc\u06a9 \u0641\u0627\u06cc\u0644 CSV \u06cc\u0627\u062f\u062f\u0627\u0634\u062a \u06a9\u0646\u06cc\u062f:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">var<\/span> someData = (\n    {\n        <span class=\"hljs-string\">\"Country\"<\/span>: <span class=\"hljs-string\">\"Nigeria\"<\/span>,\n        <span class=\"hljs-string\">\"Population\"<\/span>: <span class=\"hljs-string\">\"200m\"<\/span>,\n        <span class=\"hljs-string\">\"Continent\"<\/span>: <span class=\"hljs-string\">\"Africa\"<\/span>,\n        <span class=\"hljs-string\">\"Official Language(s)\"<\/span>: <span class=\"hljs-string\">\"English\"<\/span>\n    },\n    {\n        <span class=\"hljs-string\">\"Country\"<\/span>: <span class=\"hljs-string\">\"India\"<\/span>,\n        <span class=\"hljs-string\">\"Population\"<\/span>: <span class=\"hljs-string\">\"1b\"<\/span>,\n        <span class=\"hljs-string\">\"Continent\"<\/span>: <span class=\"hljs-string\">\"Asia\"<\/span>,\n        <span class=\"hljs-string\">\"Official Language(s)\"<\/span>: <span class=\"hljs-string\">\"Hindi, English\"<\/span>\n    },\n    {\n        <span class=\"hljs-string\">\"Country\"<\/span>: <span class=\"hljs-string\">\"United States of America\"<\/span>,\n        <span class=\"hljs-string\">\"Population\"<\/span>: <span class=\"hljs-string\">\"328m\"<\/span>,\n        <span class=\"hljs-string\">\"Continent\"<\/span>: <span class=\"hljs-string\">\"North America\"<\/span>,\n        <span class=\"hljs-string\">\"Official Language\"<\/span>: <span class=\"hljs-string\">\"English\"<\/span>\n    },\n    {\n        <span class=\"hljs-string\">\"Country\"<\/span>: <span class=\"hljs-string\">\"United Kingdom\"<\/span>,\n        <span class=\"hljs-string\">\"Population\"<\/span>: <span class=\"hljs-string\">\"66m\"<\/span>,\n        <span class=\"hljs-string\">\"Continent\"<\/span>: <span class=\"hljs-string\">\"Europe\"<\/span>,\n        <span class=\"hljs-string\">\"Official Language\"<\/span>: <span class=\"hljs-string\">\"English\"<\/span>\n    },\n    {\n        <span class=\"hljs-string\">\"Country\"<\/span>: <span class=\"hljs-string\">\"Brazil\"<\/span>,\n        <span class=\"hljs-string\">\"Population\"<\/span>: <span class=\"hljs-string\">\"209m\"<\/span>,\n        <span class=\"hljs-string\">\"Continent\"<\/span>: <span class=\"hljs-string\">\"South America\"<\/span>,\n        <span class=\"hljs-string\">\"Official Language\"<\/span>: <span class=\"hljs-string\">\"Portuguese\"<\/span>\n    }\n)\n<\/code><\/pre>\n<p>\u0631\u0627 <code>csv-stringify<\/code> \u0628\u0633\u062a\u0647 \u0647\u0645\u0686\u0646\u06cc\u0646 \u062f\u0627\u0631\u0627\u06cc \u0686\u0646\u062f \u06af\u0632\u06cc\u0646\u0647 API \u0627\u0633\u062a\u060c \u0628\u0627 \u0627\u06cc\u0646 \u062d\u0627\u0644\u060c Callback API \u06cc\u06a9 \u0631\u0627\u0647 \u0628\u0633\u06cc\u0627\u0631 \u0633\u0627\u062f\u0647 \u0628\u0631\u0627\u06cc \u0633\u062e\u062a\u200c\u0633\u0627\u0632\u06cc \u062f\u0627\u062f\u0647\u200c\u0647\u0627\u060c \u0628\u062f\u0648\u0646 \u0646\u06cc\u0627\u0632 \u0628\u0647 \u0645\u062f\u06cc\u0631\u06cc\u062a \u0631\u0648\u06cc\u062f\u0627\u062f\u0647\u0627 \u0645\u0627\u0646\u0646\u062f Stream API \u0627\u0631\u0627\u0626\u0647 \u0645\u06cc\u200c\u062f\u0647\u062f.<\/p>\n<p>\u0628\u06cc\u0627\u06cc\u06cc\u062f \u0642\u0628\u0644 \u0627\u0632 \u0646\u0648\u0634\u062a\u0646 \u0622\u0646 \u062f\u0631 \u06cc\u06a9 \u0641\u0627\u06cc\u0644\u060c \u062f\u0627\u062f\u0647\u200c\u0647\u0627\u06cc \u0628\u0627\u0644\u0627 \u0631\u0627 \u0628\u0647 \u0635\u0648\u0631\u062a \u0631\u0634\u062a\u0647\u200c\u0628\u0646\u062f\u06cc \u06a9\u0646\u06cc\u0645:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">var<\/span> fs = <span class=\"hljs-built_in\">require<\/span>(<span class=\"hljs-string\">'fs'<\/span>);\n<span class=\"hljs-keyword\">var<\/span> stringify = <span class=\"hljs-built_in\">require<\/span>(<span class=\"hljs-string\">'csv-stringify'<\/span>);\n    \nstringify(someData, {\n    <span class=\"hljs-attr\">header<\/span>: <span class=\"hljs-literal\">true<\/span>\n}, <span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span> (<span class=\"hljs-params\">err, output<\/span>) <\/span>{\n    fs.writeFile(__dirname+<span class=\"hljs-string\">'\/someData.csv'<\/span>, output);\n})\n<\/code><\/pre>\n<p>\u062f\u0631 \u0627\u06cc\u0646\u062c\u0627\u060c \u0645\u0627 \u062f\u0631 \u062d\u0627\u0644 \u0648\u0627\u0631\u062f\u0627\u062a \u0647\u0633\u062a\u06cc\u0645 <code>fs<\/code> \u0648 <code>csv-stringify<\/code> \u0645\u0627\u0698\u0648\u0644 \u0647\u0627  \u0633\u067e\u0633 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 <code>stringify()<\/code> \u062a\u0627\u0628\u0639\u060c \u062f\u0627\u062f\u0647\u200c\u0647\u0627\u06cc\u06cc \u0631\u0627 \u06a9\u0647 \u0645\u06cc\u200c\u062e\u0648\u0627\u0647\u06cc\u0645 \u0628\u0647 \u0631\u0634\u062a\u0647 \u062a\u0628\u062f\u06cc\u0644 \u06a9\u0646\u06cc\u0645\u060c \u0627\u0631\u0627\u0626\u0647 \u0645\u06cc\u200c\u06a9\u0646\u06cc\u0645.  \u0645\u0627 \u0647\u0645\u0686\u0646\u06cc\u0646 \u06cc\u06a9 \u0634\u06cc \u0628\u0647 \u0645\u0639\u0646\u0627\u06cc \u0648\u0627\u0642\u0639\u06cc \u06a9\u0644\u0645\u0647 \u0627\u0631\u0627\u0626\u0647 \u06a9\u0631\u062f\u0647 \u0627\u06cc\u0645 <code>header<\/code> \u06af\u0632\u06cc\u0646\u0647.  \u062f\u0631 \u0646\u0647\u0627\u06cc\u062a\u060c \u06cc\u06a9 \u062a\u0627\u0628\u0639 callback \u0646\u06cc\u0632 \u0648\u062c\u0648\u062f \u062f\u0627\u0631\u062f \u06a9\u0647 \u0628\u0631\u0627\u06cc \u0646\u0648\u0634\u062a\u0646 \u0645\u062d\u062a\u0648\u06cc\u0627\u062a \u062f\u0631 \u06cc\u06a9 \u0641\u0627\u06cc\u0644 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f.<\/p>\n<p>\u06af\u0632\u06cc\u0646\u0647 \u0647\u0627\u06cc \u062f\u06cc\u06af\u0631 \u0645\u0627\u0646\u0646\u062f <code>cast<\/code>\u060c <code>columns<\/code> \u0648 <code>delimiter<\/code> \u0646\u06cc\u0632 \u0645\u0648\u062c\u0648\u062f \u0647\u0633\u062a\u0646\u062f.  \u062f\u0631 \u0645\u0648\u0631\u062f \u0645\u0627\u060c \u0645\u0627 \u062f\u0631 \u062d\u0627\u0644 \u062a\u0646\u0638\u06cc\u0645 <code>header<\/code> \u06af\u0632\u06cc\u0646\u0647 \u0627\u06cc \u0628\u0647 <code>true<\/code> \u062a\u0627 \u0628\u0647 \u0631\u0634\u062a\u0647 \u0633\u0627\u0632 \u0628\u06af\u0648\u06cc\u06cc\u0645 \u0646\u0627\u0645 \u0633\u062a\u0648\u0646 \u0647\u0627 \u0631\u0627 \u062f\u0631 \u0627\u0648\u0644\u06cc\u0646 \u0631\u06a9\u0648\u0631\u062f \u062a\u0648\u0644\u06cc\u062f \u06a9\u0646\u062f.<\/p>\n<p>\u0628\u0627 \u0627\u062c\u0631\u0627\u06cc \u0627\u06cc\u0646 \u06a9\u062f \u06cc\u06a9 \u0641\u0627\u06cc\u0644 \u0628\u0627 \u0645\u062d\u062a\u0648\u0627\u06cc \u0645\u0646\u0627\u0633\u0628 \u062a\u0648\u0644\u06cc\u062f \u0645\u06cc \u0634\u0648\u062f:<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/rasanegar.com\/blog\/wp-content\/uploads\/2024\/01\/reading-and-writing-csv-files-in-nodejs-with-node-csv-1.png\" alt=\"\u0646\u0648\u0634\u062a\u0646 csv \u062f\u0631 \u06cc\u06a9 \u0641\u0627\u06cc\u0644 \u062f\u0631 nodejs\" title=\"\"><\/p>\n<h2 id=\"conclusion\"><span class=\"ez-toc-section\" id=\"%d9%86%d8%aa%db%8c%d8%ac%d9%87\"><\/span>\u0646\u062a\u06cc\u062c\u0647<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0631\u0627 <code>node-csv<\/code> \u0645\u0627\u0698\u0648\u0644 \u0645\u062c\u0645\u0648\u0639\u0647\u200c\u0627\u06cc \u0627\u0632 \u0645\u0627\u0698\u0648\u0644\u200c\u0647\u0627\u06cc \u06a9\u0648\u0686\u06a9\u200c\u062a\u0631 \u0627\u0633\u062a \u06a9\u0647 \u0628\u0631\u0627\u06cc \u062e\u0648\u0627\u0646\u062f\u0646\/\u062a\u062c\u0632\u06cc\u0647\u060c \u062a\u0628\u062f\u06cc\u0644 \u0648 \u0646\u0648\u0634\u062a\u0646 \u062f\u0627\u062f\u0647\u200c\u0647\u0627\u06cc CSV \u0627\u0632 \u0648 \u0631\u0648\u06cc \u0641\u0627\u06cc\u0644\u200c\u0647\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc\u200c\u0634\u0648\u062f.<\/p>\n<p>\u0645\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0631\u062f\u0647 \u0627\u06cc\u0645 <code>csv-parse<\/code> \u0645\u0627\u0698\u0648\u0644 \u0628\u0631\u0627\u06cc \u062e\u0648\u0627\u0646\u062f\u0646 \u0641\u0627\u06cc\u0644 \u0647\u0627\u06cc CSV \u0648 <code>csv-stringify<\/code> \u0645\u0627\u0698\u0648\u0644 \u0628\u0631\u0627\u06cc \u0631\u0634\u062a\u0647\u200c\u0628\u0646\u062f\u06cc \u062f\u0627\u062f\u0647\u200c\u0647\u0627 \u0642\u0628\u0644 \u0627\u0632 \u0646\u0648\u0634\u062a\u0646 \u0622\u0646 \u062f\u0631 \u06cc\u06a9 \u0641\u0627\u06cc\u0644 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 Node.js.<\/p>\n<\/div>\n<p>    (\u0628\u0631\u0686\u0633\u0628\u200c\u0647\u0627 \u0628\u0631\u0627\u06cc \u062a\u0631\u062c\u0645\u0647)# \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a<br \/>\n<br \/><br \/>\n<br \/>\u0645\u0646\u062a\u0634\u0631 \u0634\u062f\u0647 \u062f\u0631 1403-01-20 02:28:07<br \/>\n<\/p>\n\n\n<div class=\"kk-star-ratings kksr-auto kksr-align-center kksr-valign-bottom\"\n    data-payload='{&quot;align&quot;:&quot;center&quot;,&quot;id&quot;:&quot;16039&quot;,&quot;slug&quot;:&quot;default&quot;,&quot;valign&quot;:&quot;bottom&quot;,&quot;ignore&quot;:&quot;&quot;,&quot;reference&quot;:&quot;auto&quot;,&quot;class&quot;:&quot;&quot;,&quot;count&quot;:&quot;0&quot;,&quot;legendonly&quot;:&quot;&quot;,&quot;readonly&quot;:&quot;&quot;,&quot;score&quot;:&quot;0&quot;,&quot;starsonly&quot;:&quot;&quot;,&quot;best&quot;:&quot;5&quot;,&quot;gap&quot;:&quot;5&quot;,&quot;greet&quot;:&quot;\u0627\u0645\u062a\u06cc\u0627\u0632 \u0634\u0645\u0627 \u0628\u0647 \u0627\u06cc\u0646 \u0645\u0637\u0644\u0628&quot;,&quot;legend&quot;:&quot;0\\\/5 (0 \u0631\u0627\u06cc)&quot;,&quot;size&quot;:&quot;30&quot;,&quot;title&quot;:&quot;\u062e\u0648\u0627\u0646\u062f\u0646 \u0648 \u0646\u0648\u0634\u062a\u0646 \u0641\u0627\u06cc\u0644 \u0647\u0627\u06cc CSV \u062f\u0631 Node.js \u0628\u0627 node-csv \u06cc\u06a9 \u06a9\u0627\u0631 \u0631\u0627\u06cc\u062c \u062a\u0648\u0633\u0639\u0647 \u062e\u0648\u0627\u0646\u062f\u0646 \u062f\u0627\u062f\u0647 \u0647\u0627 \u0627\u0632 \u0641\u0627\u06cc\u0644 \u0647\u0627 \u0627\u0633\u062a.  \u06cc\u06a9 \u0641\u0631\u0645\u062a \u0631\u0627\u06cc\u062c \u0641\u0627\u06cc\u0644\u060c \u0641\u0631\u0645\u062a csv. \u0627\u0633\u062a.  \u062f\u0631 \u062d\u0627\u0644\u06cc \u06a9\u0647 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u062f \u0641\u0627\u06cc\u0644\u200c\u0647\u0627\u06cc CSV \u0631\u0627 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0645\u0627\u0698\u0648\u0644 fs \u0647\u0645\u0631\u0627\u0647 \u0628\u0627 Node \u0628\u062e\u0648\u0627\u0646\u06cc\u062f \u0648 \u0645\u062d\u062a\u0648\u0627\u06cc \u0641\u0627\u06cc\u0644 \u0631\u0627 \u062f\u0631\u06cc\u0627\u0641\u062a \u06a9\u0646\u06cc\u062f\u060c \u062f\u0631 \u0628\u06cc\u0634\u062a\u0631 \u0645\u0648\u0627\u0631\u062f\u060c \u062a\u062c\u0632\u06cc\u0647 \u0648 \u062a\u0628\u062f\u06cc\u0644 \u0628\u06cc\u0634\u062a\u0631 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 ...&quot;,&quot;width&quot;:&quot;0&quot;,&quot;_legend&quot;:&quot;{score}\\\/{best} ({count} \u0631\u0627\u06cc)&quot;,&quot;font_factor&quot;:&quot;1.25&quot;}'>\n            \n<div class=\"kksr-stars\">\n    \n<div class=\"kksr-stars-inactive\">\n            <div class=\"kksr-star\" data-star=\"1\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" data-star=\"2\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" data-star=\"3\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" data-star=\"4\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" data-star=\"5\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n    <\/div>\n    \n<div class=\"kksr-stars-active\" style=\"width: 0px;\">\n            <div class=\"kksr-star\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n    <\/div>\n<\/div>\n                \n\n<div class=\"kksr-legend\" style=\"font-size: 24px;\">\n            <span class=\"kksr-muted\">\u0627\u0645\u062a\u06cc\u0627\u0632 \u0634\u0645\u0627 \u0628\u0647 \u0627\u06cc\u0646 \u0645\u0637\u0644\u0628<\/span>\n    <\/div>\n    <\/div>\n","protected":false},"excerpt":{"rendered":"<p><span class=\"span-reading-time rt-reading-time\" style=\"display: block;\"><span class=\"rt-label rt-prefix\">\u0632\u0645\u0627\u0646 \u0644\u0627\u0632\u0645 \u0628\u0631\u0627\u06cc \u0645\u0637\u0627\u0644\u0639\u0647: <\/span> <span class=\"rt-time\"> 5<\/span> <span class=\"rt-label rt-postfix\">\u062f\u0642\u06cc\u0642\u0647<\/span><\/span>\u0645\u0639\u0631\u0641\u06cc \u06cc\u06a9 \u06a9\u0627\u0631 \u062a\u0648\u0633\u0639\u0647 \u0631\u0627\u06cc\u062c \u062e\u0648\u0627\u0646\u062f\u0646 \u062f\u0627\u062f\u0647 \u0647\u0627 \u0627\u0632 \u0641\u0627\u06cc\u0644 \u0647\u0627 \u0627\u0633\u062a. \u06cc\u06a9 \u0641\u0631\u0645\u062a \u0641\u0627\u06cc\u0644 \u0631\u0627\u06cc\u062c \u0627\u0633\u062a .csv \u0642\u0627\u0644\u0628 \u062f\u0631 \u062d\u0627\u0644\u06cc \u06a9\u0647 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0641\u0627\u06cc\u0644 \u0647\u0627\u06cc CSV \u0631\u0627 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 fs \u0645\u0627\u0698\u0648\u0644\u06cc \u06a9\u0647 \u0628\u0627 Node \u0627\u0631\u0627\u0626\u0647 \u0645\u06cc \u0634\u0648\u062f \u0648 \u0645\u062d\u062a\u0648\u0627\u06cc \u0641\u0627\u06cc\u0644 \u0631\u0627 \u062f\u0631\u06cc\u0627\u0641\u062a \u0645\u06cc \u06a9\u0646\u062f\u060c \u062f\u0631 \u0628\u06cc\u0634\u062a\u0631 \u0645\u0648\u0627\u0631\u062f\u060c \u062a\u062c\u0632\u06cc\u0647 \u0648 \u062a\u0628\u062f\u06cc\u0644 \u0628\u06cc\u0634\u062a\u0631 \u0628\u0627 \u06a9\u0645\u06a9 [&hellip;]<\/p>\n","protected":false},"author":3,"featured_media":16040,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1772,620],"tags":[],"class_list":["post-16039","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-javascript","category-programming"],"acf":[],"_links":{"self":[{"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/posts\/16039","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/users\/3"}],"replies":[{"embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/comments?post=16039"}],"version-history":[{"count":0,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/posts\/16039\/revisions"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/media\/16040"}],"wp:attachment":[{"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/media?parent=16039"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/categories?post=16039"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/tags?post=16039"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}