PGR21.com
- PGR21 관련된 질문 및 건의는 [건의 게시판]을 이용바랍니다.
- (2013년 3월 이전) 오래된 질문글은 [이전 질문 게시판]에 있습니다.
통합 규정을 준수해 주십시오. (2015.12.25.)
Date 2024/05/06 13:33:15
Name 삭제됨
Subject [삭제예정] 파이썬으로 구글 tts 사용 시 에러 (간단, 파일입출력 관련)
작성자가 본문을 삭제한 글입니다.

통합규정 1.3 이용안내 인용

"Pgr은 '명문화된 삭제규정'이 반드시 필요하지 않은 분을 환영합니다.
법 없이도 사는 사람, 남에게 상처를 주지 않으면서 같이 이야기 나눌 수 있는 분이면 좋겠습니다."
24/05/06 13:45
수정 아이콘
안녕하세요! 말씀하신 문제는 파일을 덮어쓰는 과정에서 발생하는 "Permission denied" 에러로, 이미 열려 있는 파일을 다른 프로세스에서 수정하려 할 때 나타나는 문제입니다. 몇 가지 해결 방법을 제시해 드릴게요.

1. 명시적인 파일 닫기:
playsound 라이브러리가 파일을 자동으로 닫아주지 않을 수 있습니다. playsound.playsound() 함수 호출 후에 명시적으로 파일을 닫는 코드를 추가해 보세요.

Python
from gtts import gTTS
import playsound

def play_text(text, lang):
tts = gTTS(text=text, lang=lang, slow=False)
tts.save("voice.mp3")
playsound.playsound("voice.mp3")

# 파일 명시적으로 닫기
import os
os.close(os.open("voice.mp3", os.O_RDONLY)) # 파일 열고 파일 디스크립터 얻기

# 사용 예시
play_text("안녕하세요! 반갑습니다!", 'ko')
play_text("hello! nice to meet you!", 'en')
Use code with caution.
play_circleeditcontent_copy

2. 컨텍스트 관리자 활용 (with open):

with open 구문을 사용하면 파일을 자동으로 닫아주는 장점이 있습니다. 다만, gTTS.save() 메서드는 파일 경로를 직접 받지 않고 내부적으로 파일을 처리하기 때문에, with open과 직접적으로 사용하기 어려울 수 있습니다. 다음과 같이 임시 파일을 활용하는 방식으로 해결할 수 있습니다.

Python
from gtts import gTTS
import playsound
import tempfile

def play_text(text, lang):
with tempfile.NamedTemporaryFile(delete=False, suffix=".mp3") as temp_file:
tts = gTTS(text=text, lang=lang, slow=False)
tts.save(temp_file.name)
playsound.playsound(temp_file.name)

# 사용 예시
play_text("안녕하세요! 반갑습니다!", 'ko')
play_text("hello! nice to meet you!", 'en')
Use code with caution.
play_circleeditcontent_copy
3. 다른 라이브러리 활용:

playsound 대신 pygame.mixer와 같은 다른 라이브러리를 사용하는 것도 방법입니다. pygame.mixer는 파일을 자동으로 닫아주는 기능이 있어, 파일 관련 문제를 피할 수 있습니다.

Python
from gtts import gTTS
import pygame

def play_text(text, lang):
tts = gTTS(text=text, lang=lang, slow=False)
tts.save("voice.mp3")

pygame.mixer.init()
pygame.mixer.music.load("voice.mp3")
pygame.mixer.music.play()
while pygame.mixer.music.get_busy(): # 음악 재생이 끝날 때까지 대기
pygame.time.Clock().tick(10)

# 사용 예시
play_text("안녕하세요! 반갑습니다!", 'ko')
play_text("hello! nice to meet you!", 'en')
Use code with caution.
play_circleeditcontent_copy
주의 사항:

pygame 라이브러리를 사용하려면 pip install pygame 명령으로 설치해야 합니다.
위 예시 코드에서는 음악 재생이 끝날 때까지 대기하는 로직이 포함되어 있습니다. 필요에 따라 수정하여 사용하세요.
위 방법들을 시도해 보시고, 궁금한 점이 있다면 언제든지 다시 질문해주세요!


제미나이에게 본문 내용을 복사했더니 위와 같이 답변하네요. 이중 2번을 써보니 잘 됩니다.
뻥치시네
24/05/06 14:35
수정 아이콘
와 2번 써보니까 잘되네요. 직접 돌려도 봐주시고 정말 감사해요.
생성AI도 여러개 돌려야 하나 싶네요.
chatGPT에 제 질문글을 통으로 넣고 다시 돌려 보니, 한번은 위 2번과 같은 수준으로 정확하게 알려주는데,
한 번 외 다수 번은 계속 헛소리를 하네요.
생성AI 교차 검증 필수!
감사합니다!
목록 삭게로! 맨위로
번호 제목 이름 날짜 조회
182087 [질문] 게임업계 재무쪽에서 일하시는 분들 계실까요? [4] 스웨트3170 25/11/04 3170
182086 [질문] 폰 교체시 지원금은 요즘 어디서 알아보나요? [3] 연필깍이2587 25/11/04 2587
182085 [질문] 통신선로 무상교체를 해준다고 합니다. [10] 어센틱3021 25/11/04 3021
182084 [질문] 유니버셜 스튜디오 재팬 즐기는 방법 [24] 일신1952 25/11/04 1952
182083 [질문] 유치원 선택 질문입니다. [9] 윈터2112 25/11/04 2112
182082 [질문] 차이파이류 이어폰? 중에 추천할만한거있나요? [15] 포커페쑤2540 25/11/04 2540
182081 [질문] 11월말 국내 여행지 추천 부탁드립니다. [11] 이리세3167 25/11/03 3167
182080 [질문] 이사가야하는데 세달정도 살곳이 없는데요... [14] 오렌지망고4552 25/11/03 4552
182079 [질문] 월즈 우승점수를 12점이라고 가정했을때 msi 점수는 몇점일까요? [44] Sorento4938 25/11/03 4938
182078 [질문] 롤 역전세계 lpl에 리쌍혁 있다면 [29] 삭제됨7525 25/11/03 7525
182077 [질문] [스팀]셰이프오브드림 초보의 간단 질문 [6] Mindow3002 25/11/03 3002
182076 [질문] 롤렉스 시계 줄 질문입니다 [9] 제니3055 25/11/02 3055
182075 [질문] 모니터 구매 추천 및 특가 타이밍 질문드립니다 [6] 닉을대체왜바꿈2609 25/11/02 2609
182074 [질문] 상속은 당연한 건가요? [57] 마지막승부4456 25/11/02 4456
182073 [질문] 마그네슘 영양제 추천 부탁드립니다. [8] LoveBoxeR2023 25/11/02 2023
182072 [질문] '하우스 오브 다이너마이트' 보고 궁금한 게.. [3] 정글러산군1326 25/11/02 1326
182071 [질문] 롤알못의 페이커 아타칸 킬 질문 [6] 스핔스핔1732 25/11/02 1732
182070 [질문] 안드로이드로 외부 기기 전력 전달 문제 [1] 참룡객1102 25/11/02 1102
182069 [질문] 생성형 AI로 기타타브 악보 조옮김 할수 있을까요? [7] NoWayOut1207 25/11/02 1207
182068 [질문] 서울 단풍 절정기 아직 안왔나요? [5] beloved1680 25/11/02 1680
182067 [질문] 체크카드 부정사용 신고 질문입니다. Alfine1366 25/11/02 1366
182066 [질문] 차 앞문이 안닦여요 [3] K-11447 25/11/02 1447
182065 [질문] 오리지널 워크래프트 III 키로 워크래프트 III: 리포지드의 이용 권한을 획득해야 합니다. 라고 뜨던데 [3] 지수1310 25/11/02 1310
목록 이전 다음
댓글

+ : 최근 1시간내에 달린 댓글
+ : 최근 2시간내에 달린 댓글
맨 위로