forked from sdague/transcribe_audio
-
Notifications
You must be signed in to change notification settings - Fork 0
/
watson-transcribe.py
executable file
·65 lines (55 loc) · 2.12 KB
/
watson-transcribe.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
#!/usr/bin/env python
#
# Copyright 2017 IBM
#
# Licensed under the Apache License, Version 2.0 (the "License"); you may
# not use this file except in compliance with the License. You may obtain
# a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
# License for the specific language governing permissions and limitations
# under the License.
import argparse
import configparser
import json
from os.path import join, dirname
from watson_developer_cloud import SpeechToTextV1
def get_auth():
config = configparser.RawConfigParser()
config.read('auth.cfg')
iam_apikey = config.get('watson', 'iam_apikey')
url = config.get('watson', 'url')
return (iam_apikey, url)
def parse_args():
parser = argparse.ArgumentParser(
description='Transcribe audio with watson')
parser.add_argument('file')
parser.add_argument('--customization', help="Process using a customized model id")
args = parser.parse_args()
return args
def main():
args = parse_args()
(user, passwd) = get_auth()
speech_to_text = SpeechToTextV1(
iam_apikey=user,
url=passwd,
)
speech_to_text.get_model('en-US_BroadbandModel')
with open(args.file, 'rb') as audio_file:
print("Sending audio to watson to recognize, this will take 30+ minutes")
if args.customization is not None:
print("Using custom model {0}".format(args.customization))
print("Please be patient and don't kill this process while running")
output = speech_to_text.recognize(
audio_file, content_type='audio/flac', timestamps=True,
customization_id=args.customization,
word_confidence=True)
with open("watson-transcript.json", "w") as out:
print("Transcription done, written to watson-transcription.json")
out.write(json.dumps(output.get_result(), indent=2))
if __name__ == "__main__":
main()