ArchiveBox/archivebox/parsers/generic_txt.py

53 lines
1.5 KiB
Python
Raw Normal View History

2019-04-27 21:26:24 +00:00
__package__ = 'archivebox.parsers'
__description__ = 'Plain Text'
from typing import IO, Iterable
from datetime import datetime, timezone
2019-04-27 21:26:24 +00:00
from ..index.schema import Link
2024-10-01 00:25:15 +00:00
from archivebox.misc.util import (
2019-04-27 21:26:24 +00:00
htmldecode,
enforce_types,
find_all_urls,
2019-04-27 21:26:24 +00:00
)
2019-04-27 21:26:24 +00:00
@enforce_types
def parse_generic_txt_export(text_file: IO[str], **_kwargs) -> Iterable[Link]:
2021-03-20 16:38:00 +00:00
"""Parse links from a text file, ignoring other text"""
2019-04-27 21:26:24 +00:00
text_file.seek(0)
for line in text_file.readlines():
if not line.strip():
continue
# # if the line is a local file path that resolves, then we can archive it
# if line.startswith('file://'):
# try:
# if Path(line).exists():
# yield Link(
# url=line,
# timestamp=str(datetime.now(timezone.utc).timestamp()),
# title=None,
# tags=None,
# sources=[text_file.name],
# )
# except (OSError, PermissionError):
# # nvm, not a valid path...
# pass
# otherwise look for anything that looks like a URL in the line
for url in find_all_urls(line):
2019-04-27 21:26:24 +00:00
yield Link(
url=htmldecode(url),
timestamp=str(datetime.now(timezone.utc).timestamp()),
2019-04-27 21:26:24 +00:00
title=None,
tags=None,
sources=[text_file.name],
)
KEY = 'txt'
NAME = 'Generic TXT'
PARSER = parse_generic_txt_export