הפעלת סקריפט בגוגל שיטס
-
כרגע מתאפשר לי להפעיל סקריפט רק במחשב ולא באפלקצייה בפלאפון איך אני יכול להפעיל את הסקריפט בכל זאת אולי דרך הפעלת הסקריפט מרחוק?
-
@בער כתב בהפעלת סקריפט בגוגל שיטס:
כרגע מתאפשר לי להפעיל סקריפט רק במחשב ולא באפלקצייה בפלאפון איך אני יכול להפעיל את הסקריפט בכל זאת אולי דרך הפעלת הסקריפט מרחוק?
אני חושב על פתרון כמו הפעלת הסקריפט ע"י טריגר, משהו ברעיון שהסקריפט יופעל כשבתא מסוים (לדוגמא A1) כתוב 1
אפשרי? -
@מיכאלוש כתב בהפעלת סקריפט בגוגל שיטס:
@בער בהגדרות הטריגר...
אני מסתכל שם, אבל לא רואה שהטריגר קורה כשיש שינוי בתא מסוים או עריכה בתא מסוים, קשה לי להבין מתי הטריגר יקרה......
-
@בער משהוא ידני בסגנון הזה
function blaBla() { let blabla = SpreadsheetApp.getActiveSheet().getRange('A1').getValue() if (blabla === 'כן') { //code blabla.setValue(לא); } } יש לציין שלא בדקתי עם הקוד תקין אבל העקרון הוא שהוא יזהה שבתא A1 כתוב כן אז... ובסוף יחזיר ללא
תפעיל על הקוד הזה טריגר נניח פעם בדקה -
@מיכאלוש כתב בהפעלת סקריפט בגוגל שיטס:
function blaBla() { let blabla = SpreadsheetApp.getActiveSheet().getRange('A1').getValue() if (blabla === 'כן') { //code blabla.setValue(לא); }
אם הכוונה להוסיף את זה בסקריפט עצמו, הוספתי בסוף הסקריפט ורשם לי שגיאה בשמירה.
-
@בער טריגר בעת עריכה, ותגדיר לתא מסויים ע"י שימוש ב
function onEdit(e) { var sheetName = "שם הגיליון"; var cellA1 = "A1"; var sheet_e = e.source.getActiveSheet().getName(); var cell_e = e.range.getA1Notation(); Logger.log(e) Logger.log(sheet_e) Logger.log(cell_e) if (sheet_e !== sheetName || cell_e !== cellA1) { Logger.log("The edited cell is not A1 = " + sheet_e + cell_e) return; } else { Logger.log("An edit was detected in cell A1 running a script..."); } } -
@אביי כתב בהפעלת סקריפט בגוגל שיטס:
@בער טריגר בעת עריכה, ותגדיר לתא מסויים ע"י שימוש ב
function onEdit(e) { var sheetName = "שם הגיליון"; var cellH11 = "A1"; var sheet_e = e.source.getActiveSheet().getName(); var cell_e = e.range.getA1Notation(); Logger.log(e) Logger.log(sheet_e) Logger.log(cell_e) if (sheet_e !== sheetName || cell_e !== cellA1) { Logger.log("The edited cell is not A1 = " + sheet_e + cell_e) return; } else { Logger.log("An edit was detected in cell A1 running a script..."); } } זה נשמע טוב.... אבל איפה אני כותב את זה בסקריפט עצמו? במקום אחר? איפה?
-
@אביי כתב בהפעלת סקריפט בגוגל שיטס:
@בער תפתח את עורך הסקריפטים של הקובץ, תדביק שם את הקוד הנ"ל, תתאים את שם הגיליון והתא הרלוונטיים. ובתוך הif תשים קריאה לפונקציה שאתה רוצה להפעיל, נניח לפונקציה בשם logTo תכתוב כך:
logTo();
לפונקציה שלי קוראים "myFunction20" איפה בתוך הif אני כותב את זה
@בער כתב בהפעלת סקריפט בגוגל שיטס:
function onEdit(e) { var sheetName = "מחשבון מילוי פחיות"; var cellH11 = "A1"; var sheet_e = e.source.getActiveSheet().getName(); var cell_e = e.range.getA1Notation(); Logger.log(e) Logger.log(sheet_e) Logger.log(cell_e) if (sheet_e !== sheetName || cell_e !== cellA1) { myFunction20(); } else { Logger.log("An edit was detected in cell A1 running a script..."); } } כתבתי ככה ולא מפעיל לי
-
@אביי כתב בהפעלת סקריפט בגוגל שיטס:
@בער היתה לי טעות בשם המשתנה בשורה 3 תיקנתי במקור.
אוקיי תקינתי לפי החדש וב"ה זה עובד כרגע גם בפלאפון!
תודה רבה רבה על כל העזרה וההדרכות שלך -
-
@בער כתב בהפעלת סקריפט בגוגל שיטס:
אם אני רוצה להוסיף עוד פונקציה כזאת לאותו קובץ, צריך לשנות משהו בשם של הפונקציה? כמו לכתוב onEdit1 onEdit2?
לא. אפשר להגדיר רק טריגר עריכה אחד, אבל אפשר לעשות ככה:
function onEdit(e) { var sheetName1 = "מחשבון מילוי פחיות"; var cell1 = "A1"; var sheetName2 = "מחשבון מילוי פחיות"; var cell2 = "A2"; var sheet_e = e.source.getActiveSheet().getName(); var cell_e = e.range.getA1Notation(); Logger.log(e) Logger.log(sheet_e) Logger.log(cell_e) if (sheet_e == sheetName1 || cell_e == cell1) { // כאן תרשום את שם הפונקצי להרצה במקרה וערכת את תא A1 } else if (sheet_e == sheetName2 || cell_e == cell2) { // כאן תרשום את שם הפונקציה להרצה במידה וערכת את תא A2 } else { // כאן תרשום מה יקרה במידה והתא הנערך אינו אחד מהקודמים (ניתן להשאיר ריק) } } אתה יכול להוסיף כמה טווחים וelse if שאתה רוצה...
-
@בער כתב בהפעלת סקריפט בגוגל שיטס:
יש אפשרות בתוך סקריפט שחלק מהסקריפט נמצא בקובץ אחד וחלק עובד על קובץ שני?
כן.
אתה יכול לקבל טווח בכל קובץ גוגל שיטס ולעבוד עליו בדיוק כפי שאתה עובד על הקובץ המאוגד לסקריפט, רק שתצטרך קודם לקבל את הקובץ למשתנה, וכל פעולה לבצע על המשתנה.לדוגמה באמצעות איידי
let sheetFile = SpreadsheetApp.openById("האיידי של הקובץ");
או באמצעות הלינק
let sheetFile = SpreadsheetApp.openByUrl('https://docs.google.com/spreadsheets/d/gmtumriexoprtc8um/edit');
דוגמה למימוש
function files() { fileId = `1m9wO0hnZiNxF_TpDUnIQE` sheetName = `סטטיסטיקות` var sheetFile = SpreadsheetApp.openById(fileId); Logger.log(sheetFile.getName()); // מדפיס את שם הקובץ ללוג var sheet = sheetFile.getSheetByName(sheetName); sheet.getRange('A1').setValue("אני נכתבתי באמצעות סקריפט נחמד!"); } הקוד הזה יכתוב בתא A1 בגליון בשם "סטטיסטיקות" בקובץ עם האיידי שתכניסו.
שים לב, שניתן לערוך גם קבצים בבעלות של משתמשים אחרים בתנאי שיש לך הרשאת עריכה.
-
לאחר ש @בער פנה אלי בפרטי, הוברר שלעיתים חוזרת שגיאת אימות הרשאות בקוד האחרון (לעריכת קובץ אחר), לכן במידה וזה קורה צריך להוסיף באופן ידני את היקפי ההרשאות לקובץ המניפסט של הסקריפט
"oauthScopes": [ "https://www.googleapis.com/auth/spreadsheets" ], בשביל להציג את המניפסט, יש ללחוץ על סמל ההגדרות מימין, ולסמן וי בהצג את המניפסט.
פוסט 11 מתוך 23