chaowenguo's picture
Upload 129 files
5690e11 verified
#
# Copyright (c) Microsoft. All rights reserved.
# Licensed under the MIT license. See LICENSE.md file in the project root for full license information.
#
# Note: abc = abstract base classes
from collections.abc import Mapping
from datetime import date, datetime, time, timedelta
from sys import argv
from typing import Optional
from pathlib import Path
import azure.cognitiveservices.speech as speechsdk # type: ignore
# 英文
DEFAULT_MAX_LINE_LENGTH_SBCS = 37
# 中文
DEFAULT_MAX_LINE_LENGTH_MBCS = 24
# See speech_recognize_once_compressed_input() in:
# https://github.com/Azure-Samples/cognitive-services-speech-sdk/blob/master/samples/python/console/speech_sample.py
class BinaryFileReaderCallback(speechsdk.audio.PullAudioInputStreamCallback):
def __init__(self, filename: str):
super().__init__()
self._file_h = open(filename, "rb")
def read(self, buffer: memoryview) -> int:
try:
size = buffer.nbytes
frames = self._file_h.read(size)
buffer[:len(frames)] = frames
return len(frames)
except Exception as ex:
print('Exception in `read`: {}'.format(ex))
raise
def close(self) -> None:
print('closing file')
try:
self._file_h.close()
except Exception as ex:
print('Exception in `close`: {}'.format(ex))
raise
class Read_Only_Dict(Mapping):
def __init__(self, data):
self._data = data
def __getitem__(self, key):
return self._data[key]
def __len__(self):
return len(self._data)
def __iter__(self):
return iter(self._data)
# See:
# https://stackoverflow.com/a/12448721
# https://stackoverflow.com/a/39651061
def add_time_and_timedelta(t1: time, t2: timedelta) -> time:
return (datetime.combine(date.min, t1) + t2).time()
def subtract_times(t1: time, t2: time) -> timedelta:
return datetime.combine(date.min, t1) - datetime.combine(date.min, t2)
# We cannot simply create time with ticks.
def time_from_ticks(ticks) -> time:
microseconds_1 = ticks / 10
microseconds_2 = microseconds_1 % 1000000
seconds_1 = microseconds_1 / 1000000
seconds_2 = seconds_1 % 60
minutes_1 = seconds_1 / 60
minutes_2 = minutes_1 % 60
hours = minutes_1 / 60
return time(int(hours), int(minutes_2), int(seconds_2), int(microseconds_2))
def time_from_seconds(seconds) -> time:
seconds = str.replace(str(seconds), "s", "")
milliseconds = float(seconds) * 1000
return time_from_milliseconds(milliseconds)
def time_from_milliseconds(milliseconds) -> time:
# 假设我们有毫秒数
# 将毫秒转换为微秒(timedelta 以微秒为单位)
microseconds = milliseconds * 1000
microseconds_2 = microseconds % 1000000
seconds_1 = microseconds / 1000000
seconds_2 = seconds_1 % 60
minutes_1 = seconds_1 / 60
minutes_2 = minutes_1 % 60
hours = minutes_1 / 60
return time(int(hours), int(minutes_2), int(seconds_2), int(microseconds_2))
def write_to_console(text: str, user_config: Read_Only_Dict):
if not user_config["suppress_console_output"]:
print(text, end="", flush=True)
return
def write_to_console_or_file(text: str, user_config: Read_Only_Dict):
write_to_console(text=text, user_config=user_config)
if user_config["output_file"] is not None:
file_path = Path(user_config["output_file"])
with open(file_path, mode="a", newline="", encoding='utf-8') as f:
f.write(text)
return