REFactor concat_ts_files function for improved clarity and efficiency; add clean_old_markers function to manage marker retention
This commit is contained in:
@@ -35,33 +35,32 @@ def get_ts_files(start_timestamp: float, end_timestamp: float) -> tuple[list[str
|
|||||||
|
|
||||||
return selected_files, start_offset, end_offset
|
return selected_files, start_offset, end_offset
|
||||||
|
|
||||||
|
def concat_ts_files(file_list: list[str], start_offset: float, end_offset: float, output_file: str) -> None:
|
||||||
def combine_last_x_ts_files(seconds: float, output_file: str) -> None:
|
|
||||||
ts_files = load_state()["files"]
|
|
||||||
|
|
||||||
files, start_offset, end_offset = get_ts_files(
|
|
||||||
datetime.datetime.now().timestamp() - seconds,
|
|
||||||
datetime.datetime.now().timestamp()
|
|
||||||
)
|
|
||||||
|
|
||||||
print(f"Combining files: {files} with start offset {start_offset} and end offset {end_offset}")
|
|
||||||
|
|
||||||
with open("file_list.txt", "w") as f:
|
with open("file_list.txt", "w") as f:
|
||||||
for file_path in files:
|
for file_path in file_list:
|
||||||
f.write(f"file '{file_path}'\n")
|
f.write(f"file '{file_path}'\n")
|
||||||
|
|
||||||
subprocess.run(["ffmpeg", "-y",
|
cmd = ["ffmpeg", "-y"]
|
||||||
"-ss", str(start_offset),
|
if start_offset > 0:
|
||||||
"-f", "concat", "-safe", "0", "-i",
|
cmd += ["-ss", str(start_offset)]
|
||||||
"file_list.txt",
|
cmd += ["-f", "concat", "-safe", "0", "-i", "file_list.txt", "-c", "copy"]
|
||||||
"-c", "copy",
|
if end_offset > 0:
|
||||||
output_file])
|
cmd += ["-t", str(get_duration(file_list[-1]) - end_offset - (start_offset if len(file_list) == 1 else 0))]
|
||||||
|
cmd.append(output_file)
|
||||||
|
|
||||||
|
subprocess.run(cmd)
|
||||||
os.remove("file_list.txt")
|
os.remove("file_list.txt")
|
||||||
|
|
||||||
def clip(seconds_from_end: float) -> None:
|
def clip(seconds_from_end: float) -> None:
|
||||||
output_file_name = f"{datetime.datetime.now().strftime('%Y-%m-%d %H:%M:%S')}.mp4"
|
output_file_name = f"{datetime.datetime.now().strftime('%Y-%m-%d %H:%M:%S')}.mp4"
|
||||||
combine_last_x_ts_files(seconds_from_end, output_file_name)
|
|
||||||
|
files, start_offset, end_offset = get_ts_files(
|
||||||
|
start_timestamp=datetime.datetime.now().timestamp() - seconds_from_end,
|
||||||
|
end_timestamp=datetime.datetime.now().timestamp()
|
||||||
|
)
|
||||||
|
print(f"files: {files}, start_offset: {start_offset}, end_offset: {end_offset}")
|
||||||
|
concat_ts_files(files, start_offset, end_offset, output_file_name)
|
||||||
|
|
||||||
print(f"Created clip: {output_file_name}")
|
print(f"Created clip: {output_file_name}")
|
||||||
|
|
||||||
def mark(name: str) -> None:
|
def mark(name: str) -> None:
|
||||||
@@ -98,6 +97,20 @@ def print_markers() -> None:
|
|||||||
format_time = datetime.datetime.fromtimestamp(marker['timestamp']).strftime('%Y-%m-%d %H:%M:%S')
|
format_time = datetime.datetime.fromtimestamp(marker['timestamp']).strftime('%Y-%m-%d %H:%M:%S')
|
||||||
print(f"{format_time} -> {marker['name']}")
|
print(f"{format_time} -> {marker['name']}")
|
||||||
|
|
||||||
|
def clean_old_markers() -> None:
|
||||||
|
markers_file = os.path.join(os.path.dirname(__file__), "markers.json")
|
||||||
|
if not os.path.exists(markers_file):
|
||||||
|
return
|
||||||
|
|
||||||
|
with open(markers_file, "r") as f:
|
||||||
|
markers = json.load(f)
|
||||||
|
|
||||||
|
current_time = datetime.datetime.now().timestamp()
|
||||||
|
markers = [m for m in markers if current_time - m['timestamp'] <= 60]
|
||||||
|
|
||||||
|
with open(markers_file, "w") as f:
|
||||||
|
json.dump(markers, f, indent=4)
|
||||||
|
|
||||||
def get_duration(file_path: str) -> float:
|
def get_duration(file_path: str) -> float:
|
||||||
result = subprocess.run(
|
result = subprocess.run(
|
||||||
["ffprobe", "-v", "error", "-show_entries",
|
["ffprobe", "-v", "error", "-show_entries",
|
||||||
|
|||||||
Reference in New Issue
Block a user