json-to-plain-text
json-to-plain-text copied to clipboard
json-to-plain-text is a npm module that converts JSON-like data or plain JavaScript objects to a formatted plain text representation.
json-to-plain-text
json-to-plain-text is a npm module that converts JSON-like data or plain JavaScript objects to a formatted plain text representation. It allows you to convert JSON-like data or plain JavaScript objects into human-readable format.
Installation
-
Install
json-to-plain-textnpm package.npm install json-to-plain-text -
Import the
jsonToPlainTextfunction:import { jsonToPlainText } from "json-to-plain-text";
Usage
The jsonToPlainText function accepts two parameters: data and options.
Parameters
-
data(required): The input data to convert. It can be JSON-like data or plain JavaScript objects. -
options(optional): Configuration options for customizing the output. It is an object with the following properties:-
color(boolean, default:true): Whether to apply colors to the output or not. Set totrueto add colors using thechalklibrary orfalsefor plain text output. -
seperator(string, default::): seperate keys and values. -
spacing(boolean, default:true): Whether to include spacing before colons. Set totruefor formatted spacing orfalseto remove spacing before colons. -
squareBracketsForArray(boolean, default:false): Whether to use square brackets for arrays. Set totrueto enclose arrays in square brackets orfalseto display arrays without brackets. -
doubleQuotesForKeys(boolean, default:false): Whether to use double quotes for object keys. Set totrueto wrap object keys in double quotes orfalseto keep them as they are. -
doubleQuotesForValues(boolean, default:false): Whether to use double quotes for string values. Set totrueto add double quotes around string values orfalseto display them without quotes.
-
Example
import { jsonToPlainText, Options } from "json-to-plain-text";
let data = {
place_id: "173937105",
osm_type: "way",
osm_id: "319992693",
lat: "17.861533866867224",
lon: "78.8081441896764",
display_name:
"Satadar Nagar, Ward 116 Allapur, Hyderabad, Kukatpally mandal, Telangana, 500018, India",
address: {
neighbourhood: "Satadar Nagar",
suburb: "Ward 116 Allapur",
city: "Hyderabad",
county: "Kukatpally mandal",
state: "Telangana",
postcode: "500018",
country: "India",
country_code: "in",
},
extratags: {},
namedetails: {},
boundingbox: ["17.8598497", "17.8623087", "78.8079136", "78.8082658"],
distance: 2,
};
// This is optional
const options: Options = {
color: true, // Whether to apply colors to the output or not
spacing: true, // Whether to include spacing before colons or not
seperator: ":", // seperate keys and values.
squareBracketsForArray: false, // Whether to use square brackets for arrays or not
doubleQuotesForKeys: false, // Whether to use double quotes for object keys or not
doubleQuotesForValues: false, // Whether to use double quotes for string values or not
}
// Convert the data to formatted plain text representation
const plainText = jsonToPlainText(data, options);
console.log(plainText);
Output
place_id : 173937105
osm_type : way
osm_id : 319992693
lat : 17.861533866867224
lon : 78.8081441896764
display_name : Satadar Nagar, Ward 116 Allapur, Hyderabad, Kukatpally mandal, Telangana, 500018, India
address :
neighbourhood : Satadar Nagar
suburb : Ward 116 Allapur
city : Hyderabad
county : Kukatpally mandal
state : Telangana
postcode : 500018
country : India
country_code : in
extratags : {}
namedetails : {}
boundingbox : 17.8598497, 17.8623087, 78.8079136, 78.8082658
distance : 2
💝 Sponsor and support me
If you find my projects helpful or inspiring, consider supporting me through GitHub Sponsors. Your sponsorship helps me dedicate more time and effort to open source development and creating impactful projects.
💖 Sponsors
- A huge thanks to my sponsors for their support.
License
This project is licensed under the MIT License - see the LICENSE file for details.