JS小知識(shí)之如何將CSV轉(zhuǎn)換為JSON字符串
前言
大家好,今天和大家聊一聊,在前端開(kāi)發(fā)中,我們?nèi)绾螌?CSV 格式的內(nèi)容轉(zhuǎn)換成 JSON 字符串,這個(gè)需求在我們處理數(shù)據(jù)的業(yè)務(wù)需求中十分常見(jiàn),你是如何處理的呢,如果你有更好的方法歡迎在評(píng)論區(qū)補(bǔ)充。
一、使用 csvtojson 第三方庫(kù)
您可以使用 csvtojson 庫(kù)在 JavaScript 中快速將 CSV 轉(zhuǎn)換為 JSON 字符串:
index.js
import csvToJson from 'csvtojson'; const csvFilePath = 'data.csv'; const json = await csvToJson().fromFile(csvFilePath); console.log(json);
data.csv 文件
例如這樣的 data.csv 文件,其內(nèi)容如下:
color,maxSpeed,age "red",120,2 "blue",100,3 "green",130,2
最終生成的 JSON 數(shù)組字符串內(nèi)容如下:
[ { color: 'red', maxSpeed: '120', age: '2' }, { color: 'blue', maxSpeed: '100', age: '3' }, { color: 'green', maxSpeed: '130', age: '2' } ]
安裝 csvtojson
在使用 csvtojson 之前,您需要將其安裝到我們的項(xiàng)目中。您可以使用 NPM 或 Yarn CLI 執(zhí)行此操作。
npm i csvtojson # Yarn yarn add csvtojson
安裝后,將其引入到你的項(xiàng)目中,如下所示:
import csvToJson from 'csvtojson'; // CommonJS const csvToJson = require('csvtojson');
通過(guò) fromFile() 方法,導(dǎo)入CSV文件
我們調(diào)用 csvtojson 模塊的默認(rèn)導(dǎo)出函數(shù)來(lái)創(chuàng)建將轉(zhuǎn)換 CSV 的對(duì)象。這個(gè)對(duì)象有一堆方法,每個(gè)方法都以某種方式與 CSV 到 JSON 的轉(zhuǎn)換相關(guān),fromFile() 就是其中之一。
它接受要轉(zhuǎn)換的 CSV 文件的名稱,并返回一個(gè) Promise,因?yàn)檗D(zhuǎn)換是一個(gè)異步過(guò)程。Promise 將使用生成的 JSON 字符串進(jìn)行解析。
直接將 CSV 字符串轉(zhuǎn)換為 JSON,fromString()
要直接從 CSV 數(shù)據(jù)字符串而不是文件轉(zhuǎn)換,您可以使用轉(zhuǎn)換對(duì)象的異步 fromString() 方法代替:
index.js
import csvToJson from 'csvtojson'; const csv = `"First Name","Last Name","Age" "Russell","Castillo",23 "Christy","Harper",35 "Eleanor","Mark",26`; const json = await csvToJson().fromString(csv); console.log(json);
輸出
[
{ 'First Name': 'Russell', 'Last Name': 'Castillo', Age: '23' },
{ 'First Name': 'Christy', 'Last Name': 'Harper', Age: '35' },
{ 'First Name': 'Eleanor', 'Last Name': 'Mark', Age: '26' }
]
自定義 CSV 到 JSON 的轉(zhuǎn)換
csvtojson 的默認(rèn)導(dǎo)出函數(shù)接受一個(gè)對(duì)象,用于指定選項(xiàng),可以自定義轉(zhuǎn)換過(guò)程。
其中一個(gè)選項(xiàng)是 header,這是一個(gè)用于指定 CSV 數(shù)據(jù)中的標(biāo)題的數(shù)組,可以將其替換成更易讀的別名。
index.js
import csvToJson from 'csvtojson'; const csv = `"First Name","Last Name","Age" "Russell","Castillo",23 "Christy","Harper",35 "Eleanor","Mark",26`; const json = await csvToJson({ headers: ['firstName', 'lastName', 'age'], }).fromString(csv); console.log(json);
輸出 :
[
{ firstName: 'Russell', lastName: 'Castillo', age: '23' },
{ firstName: 'Christy', lastName: 'Harper', age: '35' },
{ firstName: 'Eleanor', lastName: 'Mark', age: '26' }
]
另一個(gè)是delimeter,用來(lái)表示分隔列的字符:
import csvToJson from 'csvtojson'; const csv = `"First Name"|"Last Name"|"Age" "Russell"|"Castillo"|23 "Christy"|"Harper"|35 "Eleanor"|"Mark"|26`; const json = await csvToJson({ headers: ['firstName', 'lastName', 'age'], delimiter: '|', }).fromString(csv);
輸出
[
{ firstName: 'Russell', lastName: 'Castillo', age: '23' },
{ firstName: 'Christy', lastName: 'Harper', age: '35' },
{ firstName: 'Eleanor', lastName: 'Mark', age: '26' }
]
我們還可以使用 ignoreColumns 屬性,一個(gè)使用正則表達(dá)式示忽略某些列的選項(xiàng)。
import csvToJson from 'csvtojson'; const csv = `"First Name"|"Last Name"|"Age" "Russell"|"Castillo"|23 "Christy"|"Harper"|35 "Eleanor"|"Mark"|26`; const json = await csvToJson({ headers: ['firstName', 'lastName', 'age'], delimiter: '|', ignoreColumns: /lastName/, }).fromString(csv); console.log(json);
將 CSV 轉(zhuǎn)換為行數(shù)組
通過(guò)將輸出選項(xiàng)設(shè)置為“csv”,我們可以生成一個(gè)數(shù)組列表,其中每個(gè)數(shù)組代表一行,包含該行所有列的值。
如下所示:
index.js
import csvToJson from 'csvtojson'; const csv = `color,maxSpeed,age "red",120,2 "blue",100,3 "green",130,2`; const json = await csvToJson({ output: 'csv', }).fromString(csv); console.log(json);
輸出
[
[ 'red', '120', '2' ],
[ 'blue', '100', '3' ],
[ 'green', '130', '2' ]
]
二、使用原生的JS處理 CSV 轉(zhuǎn) JSON
我們也可以在不使用任何第三方庫(kù)的情況下將 CSV 轉(zhuǎn)換為 JSON。
index.js
function csvToJson(csv) { // \n or \r\n depending on the EOL sequence const lines = csv.split('\n'); const delimeter = ','; const result = []; const headers = lines[0].split(delimeter); for (const line of lines) { const obj = {}; const row = line.split(delimeter); for (let i = 0; i < headers.length; i++) { const header = headers[i]; obj[header] = row[i]; } result.push(obj); } // Prettify output return JSON.stringify(result, null, 2); } const csv = `color,maxSpeed,age "red",120,2 "blue",100,3 "green",130,2`; const json = csvToJson(csv); console.log(json);
輸出
[
{
"color": "color",
"maxSpeed": "maxSpeed",
"age": "age"
},
{
"color": "\"red\"",
"maxSpeed": "120",
"age": "2"
},
{
"color": "\"blue\"",
"maxSpeed": "100",
"age": "3"
},
{
"color": "\"green\"",
"maxSpeed": "130",
"age": "2"
}
]
您可以完善上面的代碼處理更為復(fù)雜的 CSV 數(shù)據(jù)。
結(jié)束
今天的分享就到這里,如何將 CSV 轉(zhuǎn)換為 JSON 字符串,你學(xué)會(huì)了嗎?
到此這篇關(guān)于JS小知識(shí)之如何將CSV轉(zhuǎn)換為JSON字符串的文章就介紹到這了,更多相關(guān)JS將CSV轉(zhuǎn)換JSON字符串內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
原文:
https://medium.com/javascript-in-plain-english/javascript-convert-csv-to-json-91dbbd4ae436作者 :Coding Beauty
非直接翻譯,有自行改編和添加部分。
相關(guān)文章
JavaScript實(shí)現(xiàn)ArrayBuffer到Base64的轉(zhuǎn)換
本文探討了在 JavaScript 中將 ArrayBuffer 轉(zhuǎn)換為 Base64 字符串時(shí)遇到的棧溢出問(wèn)題,并提供了幾種實(shí)用的解決方案,我們將通過(guò)生動(dòng)的比喻來(lái)解釋相關(guān)概念,比較不同方法的性能和兼容性,最終提供一個(gè)平衡而實(shí)用的方法,需要的朋友可以參考下2024-10-10js 判斷一個(gè)數(shù)字是不是2的n次方冪的實(shí)例
下面小編就為大家分享一篇js 判斷一個(gè)數(shù)字是不是2的n次方冪的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助2017-11-11JS正則表達(dá)式替換字符串replace()方法實(shí)例代碼
正則表達(dá)式是用于匹配字符串中字符組合的模式,在js中正則表達(dá)式是對(duì)象,這篇文章主要給大家介紹了關(guān)于JS正則表達(dá)式替換字符串replace()方法的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-07-07Omi v1.0.2發(fā)布正式支持傳遞javascript表達(dá)式
這篇文章主要介紹了Omi v1.0.2發(fā)布正式支持傳遞javascript表達(dá)式,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2017-03-03JavaScript詞法作用域與調(diào)用對(duì)象深入理解
關(guān)于 Javascript 的函數(shù)作用域、調(diào)用對(duì)象和閉包之間的關(guān)系很微妙,關(guān)于它們的文章已經(jīng)有很多,本文做了一些總結(jié),需要的朋友可以參考下2012-11-11Google 靜態(tài)地圖API實(shí)現(xiàn)代碼
Google 靜態(tài)地圖 文檔說(shuō)的很詳細(xì),這里就不在啰嗦了!2010-11-11JS面向?qū)ο缶幊袒A(chǔ)篇(一) 對(duì)象和構(gòu)造函數(shù)實(shí)例詳解
這篇文章主要介紹了JS面向?qū)ο缶幊虒?duì)象和構(gòu)造函數(shù),結(jié)合實(shí)例形式詳細(xì)分析了JS面向?qū)ο缶幊虒?duì)象和構(gòu)造函數(shù)具體概念、原理、使用方法及操作注意事項(xiàng),需要的朋友可以參考下2020-03-03BootStrap與validator 使用筆記(JAVA SpringMVC實(shí)現(xiàn))
這篇文章主要介紹了BootStrap與validator 使用筆記(JAVA SpringMVC實(shí)現(xiàn))的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-09-09