I believe your goal is as follows.
- You want to copy the cell “B” to “BW” when the cell “BY” is edited to
1. - You want to run the script by a trigger.
In this case, how about the following modification?
Modified script:
Please copy and paste the following script to the script editor and save the script. When you use this script, please put 1 to the column “BY” of “AutoQuoteDataBase” sheet. By this, the script is run.
function onEdit(e) {
var range = e.range;
var sheet = range.getSheet();
if (sheet.getSheetName() != "AutoQuoteDataBase" || range.columnStart != 77 || range.getValue() != 1) return;
sheet.getRange("B" + range.rowStart).copyTo(sheet.getRange("BW" + range.rowStart), {contentsOnly: true});
Note:
-
This script is run by a simple trigger of
onEdit. So when you directly run this script, an error likeTypeError: Cannot read property 'range' of undefinedoccurs. Please be careful about this. -
For example, when you want to copy the column “B” to the column “BW” by checking the column “BY” without using
onEdit, you can also use the following script. In this case, you can directly run this function with the script editor.function myFunction() { var ss = SpreadsheetApp.getActiveSpreadsheet(); var srcSheet = ss.getSheetByName("AutoQuoteDataBase"); var lastRow = srcSheet.getLastRow(); var values = srcSheet.getRange("A2:BY" + lastRow).getValues(); var res = values.map(r => [r[76] == 1 ? r[1] : null]); if (res.length == 0) return; srcSheet.getRange("BW2:BW" + (res.length + 1)).setValues(res); }
Reference:
2
solved How can I make the following code move information into two columns instead of one in google sheets?