内置上传工具
注意
pdfdeal
已迁移至NoEdgeAI/pdfdeal
,请前往NoEdgeAI/pdfdeal-docs 查看文档
pdfdeal
has been migrated to NoEdgeAI/pdfdeal
, please visit NoEdgeAI/pdfdeal-docs for documentation
您可能需要安装一些额外依赖以使用:
pip install --upgrade "pdfdeal[rag]"
pdfdeal
内置了一些常见的储存服务的上传工具,当然您也可以自行编写一个上传的函数--这也非常简单。
您需要与文档图像处理工具结合使用。
目前支持:
自定义函数需要0.2.4+版本
请定义一个入参接受为:
local_file_path
本地文件地址remote_file_path
远程文件地址
返回值为:
str
文件的可访问 URLbool
是否上传成功
的函数,并将其传入文档图像处理工具中的replace
。
def upload_file(local_file_path, remote_file_path):
"""Upload a file
Args:
local_file_path (str): The path of the local file to upload.
remote_file_path (str): The path of the remote file to upload to.
Returns:
tuple: A tuple containing the URL of the uploaded file and a boolean indicating whether the upload was successful.
"""
return ("This is a test",True)
如果您有好的新文件上传实现,欢迎提交 PR!
阿里云 OSS需要0.2.4+版本
请首先导入函数并使用您的阿里云 ACCESS_KEY 进行初始化。
from pdfdeal.FileTools.Img.Ali_OSS import Ali_OSS
Ali_OSS
函数需要以下参数进行初始化:
- OSS_ACCESS_KEY_ID:您的阿里云 ACCESS_KEY ID
- OSS_ACCESS_KEY_SECRET:您的阿里云 ACCESS_KEY SECRET
- Endpoint:您的 OSS 服务 Endpoint
- Bucket:您的 OSS Bucket 名称
注意
首先您需要安装包oss2
进行使用:pip install -U oss2
或pip install --upgrade "pdfdeal[rag]"
请确保您的 OSS 已经将权限设置为公开可读
示例:
from pdfdeal.FileTools.Img.Ali_OSS import Ali_OSS
from pdfdeal.file_tools import md_replace_imgs
ossupload = Ali_OSS(
OSS_ACCESS_KEY_ID=os.environ.get("OSS_ACCESS_KEY_ID"),
OSS_ACCESS_KEY_SECRET=os.environ.get("OSS_ACCESS_KEY_SECRET"),
Endpoint=os.environ.get("Endpoint"),
Bucket=os.environ.get("Bucket"),
)
md_replace_imgs(
mdfile="Output/1706.03762-2024-08-11 17-06-35.md",
replace=ossupload,
threads=5,
)
# 或者您希望替换指定路径中所有MD文档的图片为OSS地址
# mds_replace_imgs(
# path="Output",
# replace=ossupload,
# threads=5,
# )
S3需要0.2.5+版本
请首先导入函数并使用您的S3验证密匙进行初始化。
from pdfdeal.FileTools.Img.S3 import S3
S3
函数需要以下参数进行初始化:
- S3_ACCESS_KEY_ID:您的S3 ACCESS_KEY ID
- S3_ACCESS_KEY_SECRET:您的S3 ACCESS_KEY SECRET
- Endpoint:您的S3服务Endpoint
- Bucket:您的S3 Bucket名称
- Customized_Domain:您的S3自定义域名,注意
{Customized_Domain}/{remote_file_path}
将作为最终的图片地址返回。请不要忘记为自定义域名添加http://
或https://
前缀。
注意
首先您需要安装包boto3
进行使用:pip install -U boto3
或pip install --upgrade "pdfdeal[rag]"
请确保您的 S3 已经将权限设置为公开可读
示例:
from pdfdeal.FileTools.Img.S3 import S3
from pdfdeal.file_tools import md_replace_imgs
ossupload = S3(
S3_ACCESS_KEY_ID=os.environ.get("S3_ACCESS_KEY_ID"),
S3_ACCESS_KEY_SECRET=os.environ.get("S3_ACCESS_KEY_SECRET"),
Endpoint=os.environ.get("S3_Endpoint"),
Bucket=os.environ.get("S3_Bucket"),
Customized_Domain=os.environ.get("S3_Customized_Domain"),
)
md_replace_imgs(
mdfile="Output/1706.03762-2024-08-11 17-06-35.md",
replace=ossupload,
threads=5,
)
# 或者您希望替换指定路径中所有MD文档的图片为S3地址
# mds_replace_imgs(
# path="Output",
# replace=ossupload,
# threads=5,
# )
MinIO需要0.4.9+版本
您可以通过 Docker 部署开源的 MinIO 对象存储服务器。此工具同样支持通过 HTTPS 反向代理访问 MinIO 地址。
如果指定的桶(bucket_name)尚未创建,工具将自动创建一个公开可读的桶用于存储图片;如果桶已存在,则直接使用该桶。
请首先导入函数并使用您的MinIO地址,管理员账户,密码进行初始化。
from pdfdeal.FileTools.Img.MinIO import Min
Min
函数初始化时需要以下参数:
- minio_address:指定MinIO服务器地址,支持
HTTPS
、HTTP
或IP
格式,例如https://download.xxxx.top
或127.0.0.1:9000
。若为本地部署,通常为127.0.0.1:9000
。 - minio_admin:MinIO服务器的管理员账户。
- minio_password:MinIO服务器的管理员账户密码。
- bucket_name:指定存储的桶名称。请确保该桶为公开可读状态;若桶尚未创建,工具将自动创建一个公开可读的桶用于存储图片。
from pdfdeal.FileTools.Img.MinIO import Min
from pdfdeal.file_tools import md_replace_imgs
miupload = Min(
minio_address = os.environ.get("MINIO_ADDRESS"),
minio_admin = os.environ.get("MINIO_ADMIN"),
minio_password = os.environ.get("MINIO_PASSWORD"),
bucket_name = os.environ.get("BUCKET_NAME")
)
md_replace_imgs(
mdfile="Output/1706.03762-2024-08-11 17-06-35.md",
replace=miupload,
threads=5,
)
# 或者您希望替换指定路径中所有MD文档的图片为S3地址
# mds_replace_imgs(
# path="Output",
# replace=miupload,
# threads=5,
# )
PicGO需要0.4.10+版本
您可以通过PicGo上传文件,您需要自行在PicGo中设置要上传的图床。将会使用PicGo中的默认图床进行上传。注意使用PicGO上传时,其上传路径格式由PicGO决定。
from pdfdeal.FileTools.Img.PicGO import PicGO
from pdfdeal.file_tools import md_replace_imgs
picgo = PicGO(endpoint="http://127.0.0.1:36677")
md_replace_imgs(
mdfile="Output/111.md",
replace=picgo,
threads=5,
)
# 或者您希望替换指定路径中所有MD文档的图片为S3地址
# mds_replace_imgs(
# path="Output",
# replace=picgo,
# threads=5,
# )
更多...
正在赶来的路上~
如您想提交一个关于文件上传的 PR,请首先 fork项目,随后在项目的src/pdfdeal/FileTools/Img
文件夹中新建.py
文件,您可以仿照文件夹中其他上出实现完成您的上传操作,最后发起 PR🥳
感谢@Huxb12138贡献的MinIO上传工具