Categories: 'IT 인터넷'

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

업무 자동화 음성 텍스트로 변환하기 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

가수 이수 이혼 진실과 결혼 생활 고백, 미운 우리 새끼 방송 비하인드 완전 정리

가수 린이 자신의 이혼 경험을 담담히 고백하며 대중의 공감을 이끌어냈습니다. 지난해 이혼 소식이 전해진 뒤…

8시간 ago

삼전닉스 50배 레버리지 상품, 바이낸스에서 출시…해외에서만 허용되는 초고위험 투기 상품

바이낸스가 삼성전자와 SK하이닉스 주가를 기반으로 최대 50배 레버리지 투자를 가능하게 한 파생상품을 출시했습니다. 국내에서는 상상조차…

18시간 ago

조원희 옌스 비판, 남아공전 교체 투입 후 활발한 움직임 없었다는 분석

조원희 KBS 해설위원은 2026년 월드컵 남아공전 후반 교체 선수 옌스 카스트로프의 활발한 플레이를 확인할 수…

18시간 ago

촉법소년 13세 조건부 하향 2026년 개정안 공식 발표

정부가 촉법소년(형사미성년자) 연령 기준을 만 14세에서 만 13세로 조건부 하향하는 방향으로 결론을 내렸습니다. 이는 살인,…

22시간 ago

가나와 크로아티아 경기 결과, 한국 32강 진출 결정

2026년 6월 28일 오전 6시 미국 필라델피아에서 열리는 가나와 크로아티아의 L조 최종전 결과가 한국의 32강…

1일 ago

스페이스X 나스닥100 편입 7월 7일 확정…상장 한 달 만에 초고속 합류

스페이스X가 오는 7월 7일부터 나스닥100 지수에 공식 편입됩니다. 나스닥 거래소는 26일 공식 공시를 통해 결정을…

2일 ago