How To Create an Automated Data Entry Form in Google Sheets: A Step-by-Step Easy Guide (2024)

Introduction – Automated Data Entry Form in Google Sheets

In our daily work routine, there are often instances where we find ourselves tasked with entering data into databases or spreadsheet applications. Inputting data directly into the intended file can be challenging and susceptible to errors. However, by employing an Automated Data Entry Form to handle this task, we have the opportunity to expedite the data entry process and enhance accuracy significantly – up to 100%. This approach not only saves time but also ensures more reliable data input, making our professional lives more efficient and error-resistant.

How can you create an Automated Data Entry Form in Google Sheets and Apps Script?

Although Google provides a default data entry form in the form of a Google Form, for complex and large-scale data entry jobs, it is always preferable to develop an Automated Data Entry Form in Google Sheet to enhance the task’s user-friendliness and improve accuracy & speed.

Google Sheets has many advantages over the automated data entry forms in MS Excel, MS Access, and other applications installed on your local machine. It allows you to use the most advanced spreadsheet application without having to install it on your computer.

If you want to learn how to create Customer Order Form in Google Sheet and Apps Script then read this article. You will find the step-by-step YouTube tutorial too.
Customer Order Form in Google Sheet and Apps Script

Since Google Sheets is available on the cloud, you can easily access it from anywhere and at any time without any restrictions. You can also share and collaborate with colleagues, friends, and others. Furthermore, Google Apps Script enables you to add advanced features to existing applications and automate all repetitive tasks and data entry jobs.

This tutorial will teach you how to create a data entry form in Google Sheets using Apps Script. This form will cover the following features:

  • Designing the User Interface
  • Validating Inputs
  • Transferring Data
  • Search Function
  • Edit Record
  • Delete Record
  • Reset UserForm
Automated Data Entry Form - Google Sheet
Automated Data Entry Form – Google Sheet

Step by Step Guide for Automated Data Entry Form in Google Sheet

Please follow the below steps to create a data entry form in Google Sheets and Apps Script:

Creating Google Sheets for Database, UserForm and Drop-down

  1. Login to Google Drive with your existing Google ID (1) or create a new Google Account (3) and then login to Google Drive.
Login to Google Drive
Login to Google Drive with existing ID or create an account to login

2. Click on New and then click on Folder to create a new folder for our project.

Creating a Folder

3. In new folder window, just enter ‘Google Sheet Automation‘ and then click on Okay.

Google Sheet Automation Folder
Create a new folder for data entry project

4. Now open the Google Sheet Automation folder to create Google Sheet in it.

Open the Google Sheet Automation Folder

5. Right click in Google Sheet Automation folder and then select Google Sheets -> Blank spreadsheet from the pop-up menu.

Creating Google Worksheet
Creating Google Sheet

Once you will click on Blank spreadsheet, it will create and open blank spreadsheet in new tab of the browser. We will use the sheet for automated data entry form design.

6. Rename the spreadsheet with ‘Employee Data Entry Form’.

Renaming the Google Sheet
Rename the blank spreadsheet

7. Create and rename three worksheets in the newly created spreadsheet as ‘User Form‘, ‘Database‘ and ‘Support Sheet‘ .

Creating Sheets
Add three worksheets in this spreadsheet

We will utilize ‘User Form’ sheet to create an automated data entry form, ‘Database’ sheet to store the data transferred from data entry form and ‘Support Sheet’ to hold the list of departments.

8. Let’s move to the Department sheet and create a list of department in Column A.

Creating Department in Support Sheet
Creating department list

9. Let’s jump to the Database sheet and create the required column headers in row 1 starting from Column A to H e.g. Emp ID, Emp Name, Gender, Email ID, Department, Address, Submitted On and Submitted By.

Creating Columns in Database Sheet
Creating columns in Database sheet

10. Let’s move to the ‘User Form’ sheet and start designing the Employee Data Entry Form with required labels, input fields and buttons.

Employee Data Entry Form Sheet
Data Entry form designing

Here, we have one field to search the data and six input fields are for data entry job. Emp ID (C4) is input field to search the record for a particular employee with Emp ID.

Employee ID (cell C7), Employee Name (cell C9), Gender ( cell C11), Email ID (cell C13), Department (cell C15) and Address ( cell C17) are the main input fields which will be updated by user to transfer the data from this from the Database sheet. In these input fields, we will utilize Gender and Department as a drop-down.

11. To create a drop-down for Gender, just click on Data menu and then select Data Validation.

Data Validation
Creating drop-down fields

12. In Data Validation window, select ‘List of items’ from the drop-down of Criteria and enter ‘Female,Male,Other’ in text box. Tick the ‘Show dropdown list in cell’ and ‘Show validation help text:’. Enter the help text in given text box as ‘Please select Gender from the drop-down.’ Now click on Save to create the drop-down for Gender.

Data Validation Window
Creating drop-down

13. Repeat the same step to create the drop-down for Department. For Department drop-down, we will utilize the list available in Support Data sheet.

Data Validation for Department

Select ‘List from a range’ from the drop-down of Criteria and give the reference of list items available in ‘Support Data’ sheet.

In this form, we have 5 different buttons e.g. Search, Save, Modify, Delete and Clear to perform the relevant actions as per the given name.

14. To create a button, just click on Insert menu and then click on Drawing.

Create Button

15. In Drawing window, just draw a rounded rectangle and fill with desired color and give the caption as Search. After creating the button, click on Save and Close to insert the button on sheet.

Create Button in Drawing
Creating search button

16. Follow the steps 14 and 15 to create Save, Modify, Delete and Clear buttons.

Buttons
Buttons

Now, we have done with designing the form, creating drop-downs and inserting the required buttons. Let’s move to the code window.

Writing the App Script Code for Automated Data Entry Form in Google Sheet

17. To open the Apps Script window, just click on Tools menu and then click on Script Editors.

Script Editor
Tools menu

Once you click on Script editor in Tools menu, it will open the Apps Script window for Data Entry project.

App Script
Apps Script Window

18. Let’s write a function to clear the automated data entry form. We will assign this function on click event of Clear button available on User Form sheet.

// Function to Clear the User Form

function clearForm() 
{
  var myGoogleSheet= SpreadsheetApp.getActiveSpreadsheet(); //declare a variable and set with active google sheet 
  var shUserForm    = myGoogleSheet.getSheetByName("User Form"); //declare a variable and set with the User Form worksheet

  //to create the instance of the user-interface environment to use the alert features
  var ui = SpreadsheetApp.getUi();

  // Display a dialog box with a title, message, and "Yes" and "No" buttons. The user can also
  // close the dialog by clicking the close button in its title bar.
  var response = ui.alert("Reset Confirmation", 'Do you want to reset this form?',ui.ButtonSet.YES_NO);

 // Checking the user response and proceed with clearing the form if user selects Yes
 if (response == ui.Button.YES) 
  {
     
  shUserForm.getRange("C4").clear(); //Search Field
  shUserForm.getRange("C7").clear();// Employeey ID
  shUserForm.getRange("C9").clear(); // Employee Name
  shUserForm.getRange("C11").clear(); // Gender
  shUserForm.getRange("C13").clear(); // Email ID
  shUserForm.getRange("C15").clear(); //Department
  shUserForm.getRange("C17").clear();//Address

 //Assigning white as default background color

 shUserForm.getRange("C4").setBackground('#FFFFFF');
 shUserForm.getRange("C7").setBackground('#FFFFFF');
 shUserForm.getRange("C9").setBackground('#FFFFFF');
 shUserForm.getRange("C11").setBackground('#FFFFFF');
 shUserForm.getRange("C13").setBackground('#FFFFFF');
 shUserForm.getRange("C15").setBackground('#FFFFFF');
 shUserForm.getRange("C17").setBackground('#FFFFFF');

  return true ;
  
  }
}

19. Create a function to validate the data entry made by users. We will utilize this function while transferring data from User form to Database sheet.

//Declare a function to validate the entry made by user in UserForm

function validateEntry(){

  var myGooglSheet= SpreadsheetApp.getActiveSpreadsheet(); //declare a variable and set with active google sheet 
  var shUserForm    = myGooglSheet.getSheetByName("User Form"); //delcare a variable and set with the User Form worksheet

  //to create the instance of the user-interface environment to use the messagebox features
  var ui = SpreadsheetApp.getUi();

    //Assigning white as default background color

  shUserForm.getRange("C7").setBackground('#FFFFFF');
  shUserForm.getRange("C9").setBackground('#FFFFFF');
  shUserForm.getRange("C11").setBackground('#FFFFFF');
  shUserForm.getRange("C13").setBackground('#FFFFFF');
  shUserForm.getRange("C15").setBackground('#FFFFFF');
  shUserForm.getRange("C17").setBackground('#FFFFFF');
  
//Validating Employee ID
  if(shUserForm.getRange("C7").isBlank()==true){
    ui.alert("Please enter Employee ID.");
    shUserForm.getRange("C7").activate();
    shUserForm.getRange("C7").setBackground('#FF0000');
    return false;
  }

 //Validating Employee Name
  else if(shUserForm.getRange("C9").isBlank()==true){
    ui.alert("Please enter Employee Name.");
    shUserForm.getRange("C9").activate();
    shUserForm.getRange("C9").setBackground('#FF0000');
    return false;
  }
  //Validating Gender
  else if(shUserForm.getRange("C11").isBlank()==true){
    ui.alert("Please select Gender from the drop-down.");
    shUserForm.getRange("C11").activate();
    shUserForm.getRange("C11").setBackground('#FF0000');
    return false;
  }
  //Validating Email ID
  else if(shUserForm.getRange("C13").isBlank()==true){
    ui.alert("Please enter a valid Email ID.");
    shUserForm.getRange("C13").activate();
    shUserForm.getRange("C13").setBackground('#FF0000');
    return false;
  }
  //Validating Department
  else if(shUserForm.getRange("C15").isBlank()==true){
    ui.alert("Please select Department from the drop-down.");
    shUserForm.getRange("C15").activate();
    shUserForm.getRange("C15").setBackground('#FF0000');
    return false;
  }
  //Validating Address
  else if(shUserForm.getRange("C17").isBlank()==true){
    ui.alert("Please enter address.");
    shUserForm.getRange("C17").activate();
    shUserForm.getRange("C17").setBackground('#FF0000');
    return false;
  }

  return true;
  
}

20. Create a function to transfer the data from automated data entry form to Database sheet.

// Function to submit the data to Database sheet
function submitData() {
     
  var myGooglSheet= SpreadsheetApp.getActiveSpreadsheet(); //declare a variable and set with active google sheet 

  var shUserForm= myGooglSheet.getSheetByName("User Form"); //delcare a variable and set with the User Form worksheet

  var datasheet = myGooglSheet.getSheetByName("Database"); ////delcare a variable and set with the Database worksheet

  //to create the instance of the user-interface environment to use the messagebox features
  var ui = SpreadsheetApp.getUi();
  
  // Display a dialog box with a title, message, and "Yes" and "No" buttons. The user can also
  // close the dialog by clicking the close button in its title bar.
  var response = ui.alert("Submit", 'Do you want to submit the data?',ui.ButtonSet.YES_NO);

  // Checking the user response and proceed with clearing the form if user selects Yes
  if (response == ui.Button.NO) 
  {return;//exit from this function
  } 
 
  //Validating the entry. If validation is true then proceed with transferring the data to Database sheet
 if (validateEntry()==true) {
  
    var blankRow=datasheet.getLastRow()+1; //identify the next blank row

    datasheet.getRange(blankRow, 1).setValue(shUserForm.getRange("C7").getValue()); //Employee ID
    datasheet.getRange(blankRow, 2).setValue(shUserForm.getRange("C9").getValue()); //Employee Name
    datasheet.getRange(blankRow, 3).setValue(shUserForm.getRange("C11").getValue()); //Gender
    datasheet.getRange(blankRow, 4).setValue(shUserForm.getRange("C13").getValue()); // Email ID
    datasheet.getRange(blankRow, 5).setValue(shUserForm.getRange("C15").getValue()); //Department
    datasheet.getRange(blankRow, 6).setValue(shUserForm.getRange("C17").getValue());// Address
   
    // date function to update the current date and time as submittted on
    datasheet.getRange(blankRow, 7).setValue(new Date()).setNumberFormat('yyyy-mm-dd h:mm'); //Submitted On
    
    //get the email address of the person running the script and update as Submitted By
    datasheet.getRange(blankRow, 8).setValue(Session.getActiveUser().getEmail()); //Submitted By
    
    ui.alert(' "New Data Saved - Emp #' + shUserForm.getRange("C7").getValue() +' "');
  
  //Clearnign the data from the Data Entry Form

    shUserForm.getRange("C7").clear();
    shUserForm.getRange("C9").clear();
    shUserForm.getRange("C11").clear();
    shUserForm.getRange("C13").clear();
    shUserForm.getRange("C15").clear();
    shUserForm.getRange("C17").clear();
      
 }
}

21. Write the below function to search a record basis the input provided by user in Cell C4 in User Form sheet.

//Function to Search the record

function searchRecord() {
  
  var myGooglSheet= SpreadsheetApp.getActiveSpreadsheet(); //declare a variable and set with active google sheet 
  var shUserForm= myGooglSheet.getSheetByName("User Form"); //delcare a variable and set with the User Form worksheet
  var datasheet = myGooglSheet.getSheetByName("Database"); ////delcare a variable and set with the Database worksheet
    
  var str       = shUserForm.getRange("C4").getValue();
  var values    = datasheet.getDataRange().getValues(); //getting the entire values from the used range and assigning it to values variable
  var valuesFound=false; //variable to store boolean value
  
  for (var i = 0; i < values.length; i++) 
    {
    var rowValue = values[i]; //declaraing a variable and storing the value
   
    //checking the first value of the record is equal to search item
    if (rowValue[0] == str) {
           
      shUserForm.getRange("C7").setValue(rowValue[0]) ;
      shUserForm.getRange("C9").setValue(rowValue[1]);
      shUserForm.getRange("C11").setValue(rowValue[2]);
      shUserForm.getRange("C13").setValue(rowValue[3]);
      shUserForm.getRange("C15").setValue(rowValue[4]);
      shUserForm.getRange("C17").setValue(rowValue[5]);
      return; //come out from the search function
      
      }
  }

if(valuesFound==false){
  //to create the instance of the user-interface environment to use the messagebox features
  var ui = SpreadsheetApp.getUi();
  ui.alert("No record found!");
 }

}

22. Create a function to delete the record for the employee id available in cell C4.

//Function to delete the record

function deleteRow() {
  
  var myGooglSheet= SpreadsheetApp.getActiveSpreadsheet(); //declare a variable and set with active google sheet 
  var shUserForm= myGooglSheet.getSheetByName("User Form"); //delcare a variable and set with the User Form worksheet
  var datasheet = myGooglSheet.getSheetByName("Database"); ////delcare a variable and set with the Database worksheet

  //to create the instance of the user-interface environment to use the messagebox features
  var ui = SpreadsheetApp.getUi();
  
  // Display a dialog box with a title, message, and "Yes" and "No" buttons. The user can also
  // close the dialog by clicking the close button in its title bar.
  var response = ui.alert("Submit", 'Do you want to delete the record?',ui.ButtonSet.YES_NO);

 // Checking the user response and proceed with clearing the form if user selects Yes
 if (response == ui.Button.NO) 
 {return;//exit from this function
 } 
    
  var str       = shUserForm.getRange("C4").getValue();
  var values    = datasheet.getDataRange().getValues(); //getting the entire values from the used range and assigning it to values variable
  
  var valuesFound=false; //variable to store boolean value to validate whether values found or not
  
  for (var i = 0; i < values.length; i++) 
    {
    var rowValue = values[i]; //declaraing a variable and storing the value
   
    //checking the first value of the record is equal to search item
    if (rowValue[0] == str) {
      
      var  iRow = i+1; //identify the row number
      datasheet.deleteRow(iRow) ; //deleting the row

      //message to confirm the action
      ui.alert(' "Record deleted for Emp #' + shUserForm.getRange("C4").getValue() +' "');

      //Clearing the user form
      shUserForm.getRange("C4").clear() ;     
      shUserForm.getRange("C7").clear() ;
      shUserForm.getRange("C9").clear() ;
      shUserForm.getRange("C11").clear() ;
      shUserForm.getRange("C13").clear() ;
      shUserForm.getRange("C15").clear() ;
      shUserForm.getRange("C17").clear() ;

      valuesFound=true;
      return; //come out from the search function
      }
  }

if(valuesFound==false){
  //to create the instance of the user-interface environment to use the messagebox features
  var ui = SpreadsheetApp.getUi();
  ui.alert("No record found!");
 }

}

23. Write the below function to edit the existing data for employee id provided in cell C4.

//Function to edit the record

function editRecord() {
  
  var myGooglSheet= SpreadsheetApp.getActiveSpreadsheet(); //declare a variable and set with active google sheet 
  var shUserForm= myGooglSheet.getSheetByName("User Form"); //delcare a variable and set with the User Form worksheet
  var datasheet = myGooglSheet.getSheetByName("Database"); ////delcare a variable and set with the Database worksheet

  //to create the instance of the user-interface environment to use the messagebox features
  var ui = SpreadsheetApp.getUi();
  
  // Display a dialog box with a title, message, and "Yes" and "No" buttons. The user can also
  // close the dialog by clicking the close button in its title bar.
  var response = ui.alert("Submit", 'Do you want to edit the data?',ui.ButtonSet.YES_NO);

 // Checking the user response and proceed with clearing the form if user selects Yes
 if (response == ui.Button.NO) 
 {return;//exit from this function
 } 
    
  var str       = shUserForm.getRange("C4").getValue();
  var values    = datasheet.getDataRange().getValues(); //getting the entire values from the used range and assigning it to values variable
  
  var valuesFound=false; //variable to store boolean value to validate whether values found or not
  
  for (var i = 0; i < values.length; i++) 
    {
    var rowValue = values[i]; //declaraing a variable and storing the value
   
    //checking the first value of the record is equal to search item
    if (rowValue[0] == str) {
      
      var  iRow = i+1; //identify the row number

      datasheet.getRange(iRow, 1).setValue(shUserForm.getRange("C7").getValue()); //Employee ID
      datasheet.getRange(iRow, 2).setValue(shUserForm.getRange("C9").getValue()); //Employee Name
      datasheet.getRange(iRow, 3).setValue(shUserForm.getRange("C11").getValue()); //Gender
      datasheet.getRange(iRow, 4).setValue(shUserForm.getRange("C13").getValue()); // Email ID
      datasheet.getRange(iRow, 5).setValue(shUserForm.getRange("C15").getValue()); //Department
      datasheet.getRange(iRow, 6).setValue(shUserForm.getRange("C17").getValue());// Address
   
      // date function to update the current date and time as submittted on
      datasheet.getRange(iRow, 7).setValue(new Date()).setNumberFormat('yyyy-mm-dd h:mm'); //Submitted On
    
      //get the email address of the person running the script and update as Submitted By
      datasheet.getRange(iRow, 8).setValue(Session.getActiveUser().getEmail()); //Submitted By
    
      ui.alert(' "Data updated for - Emp #' + shUserForm.getRange("C7").getValue() +' "');
  
    //Clearnign the data from the Data Entry Form

      shUserForm.getRange("C4").clear();
      shUserForm.getRange("C7").clear();
      shUserForm.getRange("C9").clear();
      shUserForm.getRange("C11").clear();
      shUserForm.getRange("C13").clear();
      shUserForm.getRange("C15").clear();
      shUserForm.getRange("C17").clear();

      valuesFound=true;
      return; //come out from the search function
      }
  }

if(valuesFound==false){
  //to create the instance of the user-interface environment to use the messagebox features
  var ui = SpreadsheetApp.getUi();
  ui.alert("No record found!");
 }

}

Now, we have done with writing the functions which are required to Reset the form, Validate the entries made by users, transfer the data from User form to Database sheet, edit and delete the existing records. Let’s assign all these function to the respective buttons available in user form sheet.

24. Let’s right click on Search button then click on ellipsis (triple dots) available on the right side of button and then click on ‘Assign script’

Assign Script

25. In ‘Assign script’ window, just enter the function name and then click on OK button.

Assign Script SearchRecord

26. Follow the steps 24 and 26 to assign the Apps Script functions (e.g. submitData, editRecord, deleteRow and clearForm) to the respective buttons (e.g. Save, Modify, Delete and Clear).

So, we have done with developing an automated data entry form in Google Sheet with the help of Apps Script.

Complete YouTube Tutorial for Automated Data Entry Form in Google Sheet

Please watch the first part of the Automated Data Entry Form in Google Sheets tutorial.

Please watch the second part of the Automated Data Entry Form in Google Sheets tutorial (Search Function).

Please watch the third part of the Automated Data Entry Form in Google Sheets tutorial (Edit Function).

Please watch the fourth part of the Automated Data Entry Form in Google Sheets tutorial (Reset and Delete Functions).

Google Sheets Links for Automated Data Entry Form

You can follow the below links to open the Automated Data Entry Form in Google Sheets and see all the User Interface, Google App Script codes.

Automated Data Entry Form in Google Sheets – Link with Edit Feature

Automated Data Entry Form in Google Sheets – Link with View Feature

Download the Google Apps Script code.

Click on below button to download the Apps Script Code for ‘Automated Data Entry Form in Google Sheets’.

Download
Click to download

If you want to learn how to create Customer Order Form in Google Sheet and Apps Script then read this article. You will find the step-by-step YouTube tutorial too.
Customer Order Form in Google Sheet and Apps Script

Please share your feedback and question in comment section related with Automated Data Entry Form in Google Sheets. Thanks!

4 COMMENTS

  1. Hi there,

    I am getting the error below.

    Message details
    Exception: The parameters (String) don’t match the method signature for SpreadsheetApp.Spreadsheet.getSheetName.

  2. Hi, when trying to create these functions Google Sheets is showing an error in the last three (deleteRow, editRecord, searchRecord) that’s preventing me from saving them. Can I get advice on how to adjust these to work?

LEAVE A REPLY

Please enter your comment!
Please enter your name here

Captcha verification failed!
CAPTCHA user score failed. Please contact us!

Recommended Reads

Latest Articles