Easily Convert your Google Sheets to JSON file
data:image/s3,"s3://crabby-images/44752/4475251ab6b458bdb7f82c4ebda91873955af7bb" alt=""
You can convert your google sheets to JSON files within 5 minutes from now using these simple steps.
To start the process you’ll need to take a Google Sheet.
Here is a screenshot for Google sheet that shows a student list from multiple levels:
data:image/s3,"s3://crabby-images/9bea4/9bea42baa77dcc3235284532038930e9928f03d2" alt=""
Then click Help from the top menu and select Search from the menu items
data:image/s3,"s3://crabby-images/1f610/1f610b541469704e2c3dfd798600d41d98f77b7e" alt=""
Type Apps Script and select the Apps Script option
data:image/s3,"s3://crabby-images/b7681/b7681a1108edce49c5cc0b3b3b277b508dbc1eda" alt=""
This will take you to the Apps Script page in a new tab, here you have to edit the code in the code.gs file. Also, you can take help from App Script Sheets Documentation
data:image/s3,"s3://crabby-images/73a3b/73a3b12b892dd0e9add1742060ccf2caebe879e5" alt=""
Here is a function you can change the name. For example, here the name is studentList, and a request parameter is named req.
function studentList(req) {
}
Then take the sheet reference as a variable named studentsDoc . This is the sheet that we are working on for making JSON
function studentList(req) {
var studentsDoc = SpreadsheetApp.getActiveSpreadsheet();
}
Then we have to take our Sheet name. Here our sheet name is student_info, . You can take as many sheets as you want in the single Spreadsheet for your work purpose.
data:image/s3,"s3://crabby-images/a18da/a18da30c10a917467008329d2fa3d591d29bc082" alt=""
Now take the Sheet name as a variable.
function studentList(req) {
var studentsDoc = SpreadsheetApp.getActiveSpreadsheet();
var sheet = studentsDoc.getSheetByName('student_info');
}
You can do anything by this sheet reference like Get, Read, Edit, Add, and Remove.
Now, take the sheet’s value in a variable. In my case, I named it values, then take an empty array. I named it output for taking the values in JSON format.
function studentList(req) {
var studentsDoc = SpreadsheetApp.getActiveSpreadsheet();
var sheet = studentsDoc.getSheetByName('student_info');
var values = sheet.getDataRange().getValues();
var output = [];
}
Now we will collect the values of the sheet in the form of a separate object for each row in the array called the output.
function studentList(req) {
var studentsDoc = SpreadsheetApp.getActiveSpreadsheet();
var sheet = studentsDoc.getSheetByName('student_info');
var values = sheet.getDataRange().getValues();
var output = [];
for (var i = 0; i < values.length; i++) {
var row = {}
row['studentName'] = values[i][0];
row['gender'] = values[i][1];
row['classLevel'] = values[i][2];
row['homeState'] = values[i][3];
row['major'] = values[i][4];
output.push(row);
}
}
Now we can take output this object as a JSON file
function studentList(req) {
var studentsDoc = SpreadsheetApp.getActiveSpreadsheet();
var sheet = studentsDoc.getSheetByName('student_info');
var values = sheet.getDataRange().getValues();
var output = [];
for (var i = 0; i < values.length; i++) {
var row = {}
row['studentName'] = values[i][0];
row['gender'] = values[i][1];
row['classLevel'] = values[i][2];
row['homeState'] = values[i][3];
row['major'] = values[i][4];
output.push(row);
}
return ContentService.createTextOutput(JSON.stringify({data: output})).setMimeType(ContentService.MimeType.JSON);
}
Now, in the final stage, to deploy the document, Click the Deploy button in the right top corner then click new deployment from the dropdown
data:image/s3,"s3://crabby-images/c849b/c849bc5e04c1a6973eb7419c245a9740a0e2e919" alt=""
Then you will see a window popup. Click on the settings icon then the web app from the dropdown.
data:image/s3,"s3://crabby-images/9c08f/9c08f702701f9f95d8c1acfcfce3d1ae2ce8dd08" alt=""
Then update the App description and give access to anyone and click the Deploy button in the right bottom corner, deploying done it may take 10 to 60 seconds
data:image/s3,"s3://crabby-images/9d0a4/9d0a48ef4d7db06173c06e85b6c97db18a708210" alt=""
Then click Authorize access button in the new popup window.
data:image/s3,"s3://crabby-images/daefb/daefbc0493c61fa74e149e34537080c3d1a8a0d3" alt=""
Select your authorized email,
data:image/s3,"s3://crabby-images/3cc1d/3cc1dea8fe86894c76fdf2daea45c091fbb92b6a" alt=""
Click to advanced,
data:image/s3,"s3://crabby-images/d1f6a/d1f6a229dd28ee242862f42ab0a7ba74645c7f1d" alt=""
Click go to [your file name]
data:image/s3,"s3://crabby-images/12925/12925dad64ca29d95dce6b51096b7513655d542e" alt=""
Then allow public view access,
data:image/s3,"s3://crabby-images/c54cb/c54cba5fe34151b45945922fd4248ca11e1032e4" alt=""
Then copy the link,
data:image/s3,"s3://crabby-images/a6020/a6020f62b3e91d66010f0974417b7c19a93c340f" alt=""
Here is my studentList JSON file link to check.