Skip to content
조회 수 2272 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄

H열에 날짜가 10일 안으로 다가왔다면 메일을 발송하는 스크립트

스프레드시트에서는 특정 시간에 스크립트를 자동으로 실행하는 기능이 없기 때문에, 이 경우에는 스크립트를 주기적으로 실행시켜서 확인해야합니다.

 

이를 위해서는 Google Apps Script에서 시간 기반 트리거를 사용해야합니다.

 

다음은 H열에 저장된 날짜 값이 10일 이내인 경우에 메일을 보내는 Google Apps Script 코드의 예입니다.

 

이 코드를 스크립트 에디터에 붙여넣고 "AddTrigger" 함수를 실행하면, H열의 값이 변경될 때마다 1시간마다 스크립트가 실행되는 시간 기반 트리거가 생성됩니다.

 


 

function sendEmails() {

  var sheet = SpreadsheetApp.getActive().getSheetByName("Sheet1"); // 시트 이름에 따라 수정

  var dataRange = sheet.getDataRange();

  var values = dataRange.getValues();

  var today = new Date();

  var timezone = Session.getScriptTimeZone();

  

  for (var i = 0; i < values.length; i++) {

    var row = values[i];

    var date = row[7]; // H열에 날짜 값이 있다고 가정

    if (date != "") {

      var daysToEvent = Math.floor((date - today) / (24 * 60 * 60 * 1000)); // 날짜 차이 계산

      if (daysToEvent <= 10 && daysToEvent >= 0) { // 10일 이내인 경우 메일 보내기

        var emailAddress = row[3]; // 수신자 이메일 주소가 저장된 열에 따라 수정

        var subject = "Reminder: Event is in " + daysToEvent + " days";

        var message = "Hello,\n\nThis is a reminder that your event is in " + daysToEvent + " days.\n\nThank you.";

        MailApp.sendEmail(emailAddress, subject, message);

        sheet.getRange(i + 1, 8).setValue("Sent"); // 메일을 보낸 표시를 H열에 저장

      }

    }

  }

}

 

function AddTrigger() {

  ScriptApp.newTrigger('sendEmails')

      .timeBased()

      .everyHours(1)

      .create();

}

 

 

 

 

주의사항

이 코드에서 Sheet1은 시트 이름에 따라 수정해야합니다.

또한 이메일 주소가 저장된 열 번호와 메일 내용도 필요에 따라 수정해야합니다.

 

마지막으로, 코드를 실행하기 전에는 "Resources" 메뉴에서 "Advanced Google Services"를 활성화하고,

Gmail API를 사용할 수 있도록 권한을 부여해야합니다.

 

위의 코드에서 MailApp.sendEmail() 메소드를 사용하여 이메일을 보내기 때문에, 스크립트 실행 시간 동안 계정이 로그인되어 있어야합니다.

 

따라서 이 코드를 사용하려면 Google 계정이 로그인된 브라우저에서 스크립트를 실행해야합니다.

 

 

 

 

로그인 후 댓글쓰기가 가능합니다.

?

List of Articles
번호 분류 제목 날짜 조회 수
897 Server XE 카카오톡 글전송 2015.07.08 1223
896 컴퓨터잡담 농업경영에 이용하지 않는 농지의 처분 의무 2021.06.11 1223
895 Server WAPM에서 Database 접속 속도 개선하기 2016.03.03 1224
894 Server Windows APM Install(Apache 2.4, PHP 6.0, Mysql) 최신버전 설치해보기 2015.11.27 1246
893 Server CSS, JS파일, gzip으로 한꺼번에 압축해서 전송하기 2016.03.08 1248
892 컴퓨터잡담 자주쓰는 파이썬 명령어 2021.06.05 1249
891 Server MySQL - 속도저하에 따른 웹페이지 접속 지연 2016.03.03 1302
890 Server PHP Opcache 적용 전과 후의 비교 1 2016.03.07 1325
889 컴퓨터잡담 파이썬 파일로 읽어올 때 \n이 \\n으로 변경되는 현상 대처방법 2021.08.15 1342
888 컴퓨터잡담 Python Requests post() Method 2021.08.31 1343
887 컴퓨터잡담 파이썬 키움증권 open api 분할매매 수식구하기 2021.09.04 1344
886 Server XE 어느날 갑자기 다운로드가 되지 않을때 해결방법 file 2016.04.07 1351
885 Server 아파치 모듈 mod_deflate 압축하기 1 2016.03.17 1352
884 컴퓨터잡담 [오류해결방법] 200, Stream not found, NetStream.Play.StreamNotFound, clip: '[Clip] ... 2015.11.30 1356
883 Server XE 리퍼러 모듈로 트래픽 발생에 대처방법 file 2016.04.17 1410
882 WindowsTip Windows XP 부팅속도 개선 팁 file 2015.01.24 1413
881 Server XE 업데이트 후 모듈업데이트가 안될때 참고 file 2015.03.13 1440
880 컴퓨터잡담 파이썬 초보자가 접하기 쉬운 오류 메시지 2 2021.06.15 1441
879 컴퓨터잡담 파이썬 find, select 사용법 2021.07.30 1441
878 [Docs]스프레드시트 스프레드시트에서 삽입 버튼 만들기(chatGPT 에게 물어봄) 2023.03.09 1441
Board Pagination Prev 1 2 3 4 5 ... 46 Next
/ 46

http://urin79.com

우린친구블로그

sketchbook5, 스케치북5

sketchbook5, 스케치북5

나눔글꼴 설치 안내


이 PC에는 나눔글꼴이 설치되어 있지 않습니다.

이 사이트를 나눔글꼴로 보기 위해서는
나눔글꼴을 설치해야 합니다.

설치 취소