Spaces:
Sleeping
Sleeping
| #!/usr/bin/env python3 | |
| """ | |
| Command-line interface for Voice Summarizer | |
| """ | |
| import argparse | |
| import sys | |
| import os | |
| # Add src to path | |
| sys.path.append(os.path.dirname(__file__)) | |
| from transcription.live_transcriber import main as live_main | |
| from transcription.file_transcriber import FileTranscriber | |
| from src.analysis.llm import generate_answer | |
| from io.saver import OutputSaver | |
| def main(): | |
| parser = argparse.ArgumentParser(description="Voice Summarizer - Speech to Text and Analysis") | |
| subparsers = parser.add_subparsers(dest='command', help='Available commands') | |
| # Live transcription | |
| subparsers.add_parser('live', help='Start live transcription from microphone') | |
| # File transcription | |
| file_parser = subparsers.add_parser('transcribe', help='Transcribe an audio file') | |
| file_parser.add_argument('file', help='Path to audio file') | |
| file_parser.add_argument('--model', default='base', choices=['tiny', 'base', 'small', 'medium', 'large'], help='Whisper model size') | |
| file_parser.add_argument('--analyze', action='store_true', help='Also analyze the transcription') | |
| args = parser.parse_args() | |
| if args.command == 'live': | |
| live_main() | |
| elif args.command == 'transcribe': | |
| transcriber = FileTranscriber(model_size=args.model) | |
| transcription = transcriber.transcribe_file(args.file) | |
| print("Transcription:") | |
| print(transcription) | |
| saver = OutputSaver() | |
| session_id = saver.save_transcription(transcription) | |
| if args.analyze: | |
| analysis =generate_answer(prompt, max_new_tokens=1024) | |
| print("\nAnalysis:") | |
| print(analysis) | |
| if session_id: | |
| analysis_session_id = os.path.basename(session_id).replace('_transcript.txt', '') | |
| saver.save_analysis(analysis, analysis_session_id) | |
| else: | |
| parser.print_help() | |
| if __name__ == "__main__": | |
| main() |