Categories: 'IT 인터넷'

업무 자동화 음성 텍스트로 변환하기 with n8n & STT

Warning: getimagesize(https://i2.wp.com/blog.kakaocdn.net/dna/dAqy6Z/btsOMrGZoS9/AAAAAAAAAAAAAAAAAAAAAPdcaKm8IgO29Gng7SLh2JYrxJ2Mg07MU3pNQBiTEiw0/img.jpg?credential=yqXZFxpELC7KVnFOS48ylbz2pIh7yKj8&expires=1767193199&allow_ip&allow_referer&signature=2mWuB8OPiLpDJbRhAH4t8ys4ZHk%3D&ssl=1): Failed to open stream: HTTP request failed! HTTP/1.1 404 File Not Found in /volume1/web/aboda_re/wp-content/plugins/accelerated-mobile-pages/components/featured-image/featured-image.php on line 64 Call Stack: 0.0001 360704 1. {main}() /volume1/web/aboda_re/index.php:0 0.0001 361008 2. require('/volume1/web/aboda_re/wp-blog-header.php') /volume1/web/aboda_re/index.php:17 0.2351 8711912 3. require_once('/volume1/web/aboda_re/wp-includes/template-loader.php') /volume1/web/aboda_re/wp-blog-header.php:19 0.2351 8711912 4. do_action($hook_name = 'template_redirect') /volume1/web/aboda_re/wp-includes/template-loader.php:13 0.2351 8712128 5. WP_Hook->do_action($args = [0 => '']) /volume1/web/aboda_re/wp-includes/plugin.php:517 0.2351 8712128 6. WP_Hook->apply_filters($value = '', $args = [0 => '']) /volume1/web/aboda_re/wp-includes/class-wp-hook.php:348 0.2408 8815656 7. AMPforWP\AMPVendor\amp_render('') /volume1/web/aboda_re/wp-includes/class-wp-hook.php:324 0.5164 9513064 8. AMPforWP\AMPVendor\AMP_Post_Template->load() /volume1/web/aboda_re/wp-content/plugins/accelerated-mobile-pages/includes/vendor/amp/amp.php:95 0.5164 9513064 9. AMPforWP\AMPVendor\AMP_Post_Template->load_parts($templates = [0 => 'single']) /volume1/web/aboda_re/wp-content/plugins/accelerated-mobile-pages/includes/vendor/amp/includes/class-amp-post-template.php:160 0.5164 9513384 10. AMPforWP\AMPVendor\AMP_Post_Template->verify_and_include($file = '/volume1/web/aboda_re/wp-content/plugins/accelerated-mobile-pages/templates/design-manager/swift/single.php', $template_type = 'single') /volume1/web/aboda_re/wp-content/plugins/accelerated-mobile-pages/includes/vendor/amp/includes/class-amp-post-template.php:166 0.5187 9608512 11. include('/volume1/web/aboda_re/wp-content/plugins/accelerated-mobile-pages/templates/design-manager/swift/single.php') /volume1/web/aboda_re/wp-content/plugins/accelerated-mobile-pages/includes/vendor/amp/includes/class-amp-post-template.php:501 0.5638 9799680 12. amp_featured_image() /volume1/web/aboda_re/wp-content/plugins/accelerated-mobile-pages/templates/design-manager/swift/single.php:45 0.5638 9799680 13. ampforwp_framework_get_featured_image() /volume1/web/aboda_re/wp-content/plugins/accelerated-mobile-pages/components/components-core.php:225 0.5731 9800832 14. getimagesize($filename = 'https://i2.wp.com/blog.kakaocdn.net/dna/dAqy6Z/btsOMrGZoS9/AAAAAAAAAAAAAAAAAAAAAPdcaKm8IgO29Gng7SLh2JYrxJ2Mg07MU3pNQBiTEiw0/img.jpg?credential=yqXZFxpELC7KVnFOS48ylbz2pIh7yKj8&expires=1767193199&allow_ip&allow_referer&signature=2mWuB8OPiLpDJbRhAH4t8ys4ZHk%3D&ssl=1') /volume1/web/aboda_re/wp-content/plugins/accelerated-mobile-pages/components/featured-image/featured-image.php:64

업무 자동화 음성 텍스트로 변환하기 with n8n & STT   음성 파일을 자동으로 텍스트로 변환하는 STT(Speech-to-Text) 기능은 다양한 업무 자동화에 활용될 수 있습니다. 특히 n8n과 Google Drive를 연동하면, 파일 업로드 시 자동으로 음성을 텍스트로 변환하는 강력한 자동화 시스템을 구성할 수 있습니다. 본문에서는 STT 구현 방법과 함께, 이를 n8n으로 자동화하는 실제 워크플로우 구성 방법까지 안내드립니다.

업무 자동화 음성 텍스트로 변환하기 with n8n & STT  

업무 자동화 음성 텍스트로 변환하기 with n8n & STT

STT(Speech-to-Text)란 무엇인가요?

STT는 음성을 인식하여 텍스트로 변환하는 기술로, 음성 회의 기록, 고객 서비스 녹취 분석, 뉴스 스크립트 자동화 등 다양한 영역에서 활용됩니다. TTS(Text-to-Speech)의 반대 개념이며, AI 음성 인식 기술의 핵심 요소입니다.

STT 구현 방법 3가지

1. Google Cloud Speech-to-Text API

Google의 STT API는 고정밀 음성 인식 서비스를 제공합니다.

  • Google Cloud 프로젝트 생성 후, Speech-to-Text API 활성화
  • 서비스 계정 키(JSON) 발급 및 인증 설정
  • 다음과 같은 Python 코드로 음성 텍스트 변환
import os
from google.cloud import speech

os.environ["GOOGLE_APPLICATION_CREDENTIALS"] = "your_key.json"

def transcribe(audio_file):
    client = speech.SpeechClient()
    with open(audio_file, "rb") as f:
        content = f.read()

    audio = speech.RecognitionAudio(content=content)
    config = speech.RecognitionConfig(
        encoding=speech.RecognitionConfig.AudioEncoding.LINEAR16,
        sample_rate_hertz=16000,
        language_code="ko-KR"
    )

    response = client.recognize(config=config, audio=audio)
    for result in response.results:
        print(result.alternatives[0].transcript)

2. SpeechRecognition 라이브러리

Python 기반 오픈소스 라이브러리로, Google Web Speech API 등을 사용할 수 있습니다.

  • 라이브러리 설치: pip install SpeechRecognition pydub
  • mp3 → wav 변환 후 인식 진행
from pydub import AudioSegment
import speech_recognition as sr

def convert_audio(input_file, output_file):
    AudioSegment.from_file(input_file).export(output_file, format="wav")

def recognize_speech(audio_file):
    r = sr.Recognizer()
    with sr.AudioFile(audio_file) as source:
        audio = r.record(source)
    print(r.recognize_google(audio, language="ko-KR"))

3. OpenAI Whisper 모델

Whisper는 다양한 언어를 지원하는 고성능 STT 모델로, 오픈소스로 제공됩니다.

  • 설치: pip install git+https://github.com/openai/whisper.git
  • 간단한 코드로 텍스트 변환
import whisper

model = whisper.load_model("base")
result = model.transcribe("sample_audio.mp3")
print(result["text"])

n8n으로 STT 자동화 워크플로우 만들기

n8n으로 STT 자동화 워크플로우 만들기

Google Drive에 음성 파일이 업로드되면, 자동으로 이를 감지하고 STT 변환 후 텍스트 결과를 저장하는 n8n 워크플로우 구성 방법입니다.

n8n을 아직 설치안하셨다면 해당 내용을 먼저 참고해보세요!

2024.12.15 – [제품추천/소프트웨어] – n8n 시놀로지 로컬 설치 쉽게 하는 방법

n8n 시놀로지 로컬 설치 쉽게 하는 방법

n8n 시놀로지 로컬 설치 쉽게 하는 방법 ㅣ n8n(n-eight-n으로 발음)은 전 세계의 모든 API 앱을 서로 연결하여 코드 한 줄 없이 데이터를 공유하고 조작할 수 있도록 도와줍니다. 사용하기 쉽고 사용

aboda.kr

 

1. Google Drive 트리거 설정

  • Google Drive Trigger 노드를 추가
  • 인증 설정 및 대상 폴더 지정
  • 파일 생성 이벤트 발생 시 워크플로우 실행

2. 파일 다운로드

  • HTTP Request 노드를 추가하여, Google Drive 트리거에서 받은 URL로 파일 다운로드

3. Execute Command로 Python 스크립트 실행

Python 코드를 n8n의 Execute Command 노드로 실행합니다. 아래 예시는 Google Cloud API를 활용한 변환 스크립트입니다.

import os
import requests
from google.cloud import speech

os.environ["GOOGLE_APPLICATION_CREDENTIALS"] = "your_key.json"

def download_file(url, local_path):
    with requests.get(url, stream=True) as r:
        r.raise_for_status()
        with open(local_path, 'wb') as f:
            for chunk in r.iter_content(8192):
                f.write(chunk)

def transcribe(audio_file):
    client = speech.SpeechClient()
    with open(audio_file, "rb") as f:
        content = f.read()
    audio = speech.RecognitionAudio(content=content)
    config = speech.RecognitionConfig(
        encoding=speech.RecognitionConfig.AudioEncoding.LINEAR16,
        sample_rate_hertz=16000,
        language_code="ko-KR"
    )
    response = client.recognize(config=config, audio=audio)
    return "\n".join([r.alternatives[0].transcript for r in response.results])

url = "URL_FROM_N8N"
file_path = "audio.wav"
download_file(url, file_path)
print(transcribe(file_path))

4. 결과 저장 및 처리

  • Set 노드 또는 Google Sheets 노드를 활용해 변환된 텍스트 저장
  • Slack, 이메일, 노션 등으로 알림 전송도 가능

활용 예시

  • 회의 녹음 파일 자동 기록화
  • 전화 상담 녹취 분석 자동화
  • 교육 강의 자동 요약 및 저장

마무리

n8n과 STT 기능을 결합하면 음성 기반 데이터를 자동으로 분석하고 저장하는 자동화 시스템을 간단하게 구축할 수 있습니다. 코드 지식이 많지 않더라도, 위 워크플로우를 따라 하시면 누구나 구현할 수 있습니다.

관련 글
n8n자동화, 음성텍스트변환, STT자동화, 구글STTAPI, openaiWhisper, 음성인식워크플로우, GoogleDrive트리거, 자동음성기록, n8nExecuteCommand, STT스크립트

2025.06.20 – [부동산/자동화 프로젝트] – n8n Slack으로 자동 메시지 보내기 완전 쉬워요 (1/1)

n8n Slack으로 자동 메시지 보내기 완전 쉬워요 (1/1)

n8n Slack으로 자동 메시지 보내기 완전 쉬워요 , n8n을 활용한 자동화 워크플로우 시간입니다. 이번에는 Slack 채널로 알림 메시지를 자동 전송하는 방법을 소개드립니다. 환율 정보, 에러 발생 알림

aboda.kr

urjent

Share
Published by
urjent

Recent Posts

첨밀밀 등려군 장만옥: 90년대 홍콩 멜로의 전설 다시 보기

1996년, 홍콩 영화사에 이름을 새긴 명작 '첨밀밀'. 여명과 장만옥이 선보인 감정선은 지금도 많은 이들에게 강렬한…

1시간 ago

2026 한강대학가요제: 청춘의 열정이 피어난 음악 축제

2026 한강대학가요제는 국내외 189개팀이 참여한 순수 창작곡 경연대회로, 최종 우승은 ‘가로인들’이 차지했다. 서울 잠원한강공원 다목적운동장에서…

1시간 ago

북중미 월드컵 대한민국 명단 26인 발표, 홍명보 감독 전술 전략 파헤치기

2026년 북중미 월드컵 한국 대표팀 최종 26인 명단이 오늘 오후 4시, 서울 KT 광화문 KT…

11시간 ago

아이유 3억 기부, 팬과 함께한 특별한 생일 선물의 의미

가수 겸 배우 아이유가 자신의 33번째 생일을 맞아 3억 원의 거액을 기부하며 연예계 대표 기부…

14시간 ago

교생실습 영화 개봉 3일차 박스오피스 7위, 수능 귀신과 흑마술 동아리의 공포 코믹스

교생실습 영화는 5월 13일 CGV 단독 개봉한 공포 코미디로, 개봉 3일차인 5월 15일 기준 박스오피스…

16시간 ago

2026 중랑 서울장미축제 (5.15~23) 국내 최대 5.45km 장미터널 걷는 법 가이드

2026년 5월, 서울 중랑구가 붉은 빛으로 물든다. 제18회를 맞는 중랑 서울장미축제가 15일부터 23일까지 중랑천 일원에서…

19시간 ago