選択できるのは25トピックまでです。 トピックは、先頭が英数字で、英数字とダッシュ('-')を使用した35文字以内のものにしてください。

download_deps.py 3.5KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  1. #!/usr/bin/env python3
  2. # PEP 723 metadata
  3. # /// script
  4. # requires-python = ">=3.10"
  5. # dependencies = [
  6. # "huggingface-hub",
  7. # "nltk",
  8. # "argparse",
  9. # ]
  10. # ///
  11. from huggingface_hub import snapshot_download
  12. from typing import Union
  13. import nltk
  14. import os
  15. import urllib.request
  16. import argparse
  17. def get_urls(use_china_mirrors=False) -> Union[str, list[str]]:
  18. if use_china_mirrors:
  19. return [
  20. "http://mirrors.tuna.tsinghua.edu.cn/ubuntu/pool/main/o/openssl/libssl1.1_1.1.1f-1ubuntu2_amd64.deb",
  21. "http://mirrors.tuna.tsinghua.edu.cn/ubuntu-ports/pool/main/o/openssl/libssl1.1_1.1.1f-1ubuntu2_arm64.deb",
  22. "https://repo.huaweicloud.com/repository/maven/org/apache/tika/tika-server-standard/3.0.0/tika-server-standard-3.0.0.jar",
  23. "https://repo.huaweicloud.com/repository/maven/org/apache/tika/tika-server-standard/3.0.0/tika-server-standard-3.0.0.jar.md5",
  24. "https://openaipublic.blob.core.windows.net/encodings/cl100k_base.tiktoken",
  25. ["https://registry.npmmirror.com/-/binary/chrome-for-testing/121.0.6167.85/linux64/chrome-linux64.zip", "chrome-linux64-121-0-6167-85"],
  26. ["https://registry.npmmirror.com/-/binary/chrome-for-testing/121.0.6167.85/linux64/chromedriver-linux64.zip", "chromedriver-linux64-121-0-6167-85"],
  27. ]
  28. else:
  29. return [
  30. "http://archive.ubuntu.com/ubuntu/pool/main/o/openssl/libssl1.1_1.1.1f-1ubuntu2_amd64.deb",
  31. "http://ports.ubuntu.com/pool/main/o/openssl/libssl1.1_1.1.1f-1ubuntu2_arm64.deb",
  32. "https://repo1.maven.org/maven2/org/apache/tika/tika-server-standard/3.0.0/tika-server-standard-3.0.0.jar",
  33. "https://repo1.maven.org/maven2/org/apache/tika/tika-server-standard/3.0.0/tika-server-standard-3.0.0.jar.md5",
  34. "https://openaipublic.blob.core.windows.net/encodings/cl100k_base.tiktoken",
  35. ["https://storage.googleapis.com/chrome-for-testing-public/121.0.6167.85/linux64/chrome-linux64.zip", "chrome-linux64-121-0-6167-85"],
  36. ["https://storage.googleapis.com/chrome-for-testing-public/121.0.6167.85/linux64/chromedriver-linux64.zip", "chromedriver-linux64-121-0-6167-85"],
  37. ]
  38. repos = [
  39. "InfiniFlow/text_concat_xgb_v1.0",
  40. "InfiniFlow/deepdoc",
  41. "InfiniFlow/huqie",
  42. "BAAI/bge-large-zh-v1.5",
  43. "maidalun1020/bce-embedding-base_v1",
  44. ]
  45. def download_model(repo_id):
  46. local_dir = os.path.abspath(os.path.join("huggingface.co", repo_id))
  47. os.makedirs(local_dir, exist_ok=True)
  48. snapshot_download(repo_id=repo_id, local_dir=local_dir)
  49. if __name__ == "__main__":
  50. parser = argparse.ArgumentParser(description='Download dependencies with optional China mirror support')
  51. parser.add_argument('--china-mirrors', action='store_true', help='Use China-accessible mirrors for downloads')
  52. args = parser.parse_args()
  53. urls = get_urls(args.china_mirrors)
  54. for url in urls:
  55. download_url = url[0] if isinstance(url, list) else url
  56. filename = url[1] if isinstance(url, list) else url.split("/")[-1]
  57. print(f"Downloading {filename} from {download_url}...")
  58. if not os.path.exists(filename):
  59. urllib.request.urlretrieve(download_url, filename)
  60. local_dir = os.path.abspath('nltk_data')
  61. for data in ['wordnet', 'punkt', 'punkt_tab']:
  62. print(f"Downloading nltk {data}...")
  63. nltk.download(data, download_dir=local_dir)
  64. for repo_id in repos:
  65. print(f"Downloading huggingface repo {repo_id}...")
  66. download_model(repo_id)