본문 바로가기

Home > 열린마당 > 공개SW 소식

공개SW 소식

R을 사용해 아웃룩 이메일과 팀즈 메시지를 보내는 방법

support 게시글 작성 시각 2021-11-29 11:25:26 게시글 조회수 5280

2021.11.29.
ⓒITWorld / Sharon Machlis | InfoWorld

 

R로 데이터를 분석하고 마이크로소프트 365를 통해 정보를 공유하는 이들에게 좋은 소식이 있다. 아웃룩, 팀즈, 원드라이브, 셰어포인트와 R을 쉽게 연결할 수 있게 됐다. 마이크로소프트 애저 팀이 개발한 마이크로소프트365R(Microsoft365R) R 패키지에는 R에서 마이크로소프트 365 API를 사용할 수 있는 함수가 추가됐다.

이를 이용해 아웃룩 이메일과 팀즈 메시지를 R로 보내는 방법을 살펴보자. 마이크로소프트365R은 CRAN에서 제공되므로 install.packages("Microsoft365R")을 사용해 설치하면 된다.
 
아웃룩과 연결되도록 R 인증하기 
첫 단계는 계정과 연결되도록 R을 인증하는 것이다. 여기에 사용되는 함수는 마이크로소프트 365 서비스에 따라, 그리고 계정이 비즈니스 계정인지 개인 계정인지에 따라 다르다. 예를 들어 기업 아웃룩 계정을 인증하려면 마이크로소프트365R 패키지를 로드한 후 다음과 같이 이 패키지의 get_business_outlook() 함수를 사용한다. 
 
library(Microsoft365R) 
my_outlook <- get_business_outlook() 

이 코드를 사용하면 ms_outlook 클래스의 새 개체인 my_outlook을 만든다. 개인용 아웃룩 계정을 사용한다면 이 함수 대신 get_personal_outlook() 함수를 사용한다. 회사 계정에서는 “관리자가 구성한 정책으로 인해” 인증이 실패했다는 오류가 표시되면서 제대로 되지 않을 수 있다. 마이크로소프트365R 인증 설명서(vignette)를 보면 이 문제에 대처하는 몇 가지 방법이 나와 있다. 기본 R 설명서 함수인 vignette("auth", package = "Microsoft365R")을 실행하면 설명서를 볼 수 있다. 이 설명서는 도움이 되는 정보가 포함된 다른 페이지로 연결된다. 

굵은 글꼴로 표시된 앱 ID가 마이크로소프트의 공식 앱 ID다. 다음과 같이 이 ID를 인증 함수의 인수로 첨부하면 인증 문제가 해결되는 경우가 있다. 
 
my_outlook <- get_business_outlook(app = "d44a05d5-c6a5-4bbb-82d2-443123722380") 

다시 말하지만, 이 앱 ID는 필자의 환경에 국한된 것이 아니라 마이크로소프트의 공식 앱 ID다. 회사 IT 부서에서 이에 관해 물어본다면 마이크로소프트 애저팀이 직접 만든 문서에 나오는 방법이라고 자신 있게 설명하면 된다. 제대로 된다면 브라우저 창이 열리면서 마이크로소프트 계정에 로그인하라는 메시지가 표시되고 앱이 인증된다. 
 
R을 사용해 아웃룩 이메일 보내기 
새 아웃룩 연결을 활용하면 이메일 읽기, 삭제하기를 비롯해 많은 일을 할 수 있다. 개인적으로 가장 흥미로운 부분은 이메일 보내기다. 이메일을 보내려면 다음과 같이 먼저 ms_outlook 개체의 create_mail() 메서드를 사용해 이메일 개체를 만든다. 
 
my_email <- my_outlook$create_email("Body text I want in my email", 
subject = "Email subject", to = "recipient@email.com") 

코드를 실행해 이메일 개체를 만들면 임시 보관 이메일이 아웃룩 임시 보관함 폴더에 저장된다. 이메일을 만드는 데 사용하는 구문은 몇 가지 더 있다. 다음 코드에서 달러 기호는 여러 메서드를 연결하는 파이프 역할을 한다. 
 
my_email <- my_outlook$create_email(content_type = "html")$ 
set_body("<p>This is my email body <strong>with bold text</strong>.</p>")$ 
set_subject("My 2nd email subject")$ 
set_recipients(to = c("recipient1@mail.com", "recipient2@mail.com")) 

이 코드는 HTML 콘텐츠 형식의 이메일 개체를 만들며 메시지에서 HTML 서식을 사용한다. 또한 여러 명의 받는 사람을 포함한다. 이 방법으로 이메일 개체를 만드는 경우에도 메시지가 생성되어 아웃룩 임시 보관함 폴더에 나타난다. 

마이크로소프트365R을 블래스툴라(blastula) 패키지와 연결하면 이메일 본문에서 원시 HTML 대신 마크다운을 사용할 수 있다. 이렇게 하려면 먼저 블래스툴라 패키지를 로드한 다음 마크다운을 R 문자열로 저장한다. 다음 예제 코드에서는 마크다운을 blastula_body_text라는 변수에 저장한다. 
 
library(blastula) 
blastula_body_text <- "This is my email body with _italics text_. As with usual markdown, **two blank lines** create a new paragraph and two asterisks bold text." 

그다음 블래스툴라의 compose_email() 함수를 사용해 마크다운 서식의 문자열을 블래스툴라 이메일 개체로 바꾼다. 문자열은 body 인수로 들어가지만 블래스툴라의 md() 함수 안에 래핑되므로 compose_email()은 본문 안에 렌더링해야 하는 마크다운이 있음을 안다. 
(후략)

 

[원문 기사 : https://www.itworld.co.kr/news/216399 ] 

 

※ 본 내용은 한국아이디지(주) (https://www.idg.co.kr/)의 저작권 동의에 의해 공유되고 있습니다.
Copyright ⓒ 2020 International Data Group. 무단전재 및 재배포 금지. 

맨 위로
맨 위로