![Oracle Drags Its Feet in the JavaScript Trademark Dispute](https://cdn.sanity.io/images/cgdhsj6q/production/919c3b22c24f93884c548d60cbb338e819ff2435-1024x1024.webp?w=400&fit=max&auto=format)
Security News
Oracle Drags Its Feet in the JavaScript Trademark Dispute
Oracle seeks to dismiss fraud claims in the JavaScript trademark dispute, delaying the case and avoiding questions about its right to the name.
Node module to convert CSV to JSON and JSON to CSV.
CSV Tools does a great job exporting and importing data. Javascript objects can easily be exported to CSV, a format that non-programmers can easily understand and modify. On the other hand, CSV data can be imported into your appliation using CSV Tools and easily use that data as JSON objects.
This libraries provides 3 methods:
CSV Tools can parse any CSV file or string to an array of JSONs. The CVS's first row must contain the headers and the JSON properties will be named as the header for the corresponding column.
For example, the following CSV:
first_name,last_name,gender
Dennis,Anderson,Male
Peter,Hicks,Male
will be converted into:
[
{
"first_name": "Dennis",
"last_name": "Anderson",
"gender": "Male"
},
{
"first_name": "Peter",
"last_name": "Hicks",
"gender": "Male"
}
]
A dot (.) in a header will create a subdocument. For example:
device,owner.name.first,owner.name.last,owner.gender
94-0B-05-0E-E9-35,Pamela,Hart,Female
69-71-86-FD-B1-24,Karen,Pierce,Female
will be converted into:
[
{
"device": "94-0B-05-0E-E9-35",
"owner": {
"name": {
"first": "Pamela",
"last": "Hart"
},
"gender": "Female"
}
},
{
"device": "69-71-86-FD-B1-24",
"owner": {
"name": {
"first": "Karen",
"last": "Pierce"
},
"gender": "Female"
}
}
]
In the same way, JSONs can be converted into CSV. The properties will be stored as headers in the first row of the CSV. If the JSON has subdocuments, its properties will be attached to the corresponding header with a dot between the parent property and its children. For example:
[
{
"age": 21,
"name": {
"first": "Sylvia",
"last": "Mcfarland"
},
"company": "AMRIL",
"phone": "+1 (919) 503-3392"
},
{
"age": 21,
"name": {
"first": "Adkins",
"last": "Becker"
},
"company": "COMTREK",
"phone": "+1 (938) 564-3477"
}
]
will be converted into:
age,name.first,name.last,company,phone
21,"Sylvia","Mcfarland","AMRIL","+1 (919) 503-3392"
21,"Adkins","Becker","COMTREK","+1 (938) 564-3477"
If any of the objects in the array does not have a property, that value will be empty in the resulting CSV.
Input:
[
{
"age": 21,
"phone": "+1 (919) 503-3392",
"name": "Sylvia Mcfarland"
},
{
"age": 34,
"name": "Adkins Becker",
}
]
Output:
age,phone,name
21,"+1 (919) 503-3392","Sylvia Mcfarland"
34,,"Adkins Becker"
$ npm install csv-tools
To use this module:
var csv = require('csv-tools');
csvData
<string>delimiter
<string> Default: ,
Convert csvData
to JSON.
delimiter
refers to the character used to separate CVS columns. Comma (,) by default.
var csv = require('csv-tools');
var csvData = "first_name,last_name,gender\nDennis,Anderson,Male\nPeter,Hicks,Male";
var json = csv.toJSON(csvData);
console.log(JSON.stringify(json, null, 2));
csvFilePath
<string>delimiter
<string> Default: ,
callback
<Function>data
<Object> A JSON object with the data in the CVS fileConvert the CSV file in csvFilePath
to JSON. The callback gets one argument (data)
where data
is a JSON with the data in the CSV file.
delimiter
refers to the character used to separate CVS columns. Comma (,) by default.
var csv = require('csv-tools');
var file = "data.csv";
csv.fileToJSON(file, function(json) {
console.log(JSON.stringify(json,null,2));
});
Convert jsonArray
to CSV.
delimiter
refers to the character used to separate CVS columns. Comma (,) by default.
var csv = require('csv-tools');
var jsonArray = [
{
"first_name": "Dennis",
"last_name": "Anderson",
"gender": "Male"
},
{
"first_name": "Peter",
"last_name": "Hicks",
"gender": "Male"
}
];
var csvData = csv.fromJSON(jsonArray);
console.log(csvData);
FAQs
Convert CSV to JSON and JSON to CSV.
The npm package csv-tools receives a total of 132 weekly downloads. As such, csv-tools popularity was classified as not popular.
We found that csv-tools demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Oracle seeks to dismiss fraud claims in the JavaScript trademark dispute, delaying the case and avoiding questions about its right to the name.
Security News
The Linux Foundation is warning open source developers that compliance with global sanctions is mandatory, highlighting legal risks and restrictions on contributions.
Security News
Maven Central now validates Sigstore signatures, making it easier for developers to verify the provenance of Java packages.