吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 1236|回复: 8
收起左侧

[经验求助] 根据ExceL里的数据将图片放到对应的文件夹

[复制链接]
TxAlex 发表于 2024-4-14 10:18
50吾爱币
根据ExceL里的“页数”批量将每条目录对应图片放在和ExceL里的“档号”命名的文件夹中。
例如:Excel表格中第一条档号:ZCKD-B4.406-D30-001 页数10,把文件夹中001-010的图片放进ZCKD-B4.406-D30-001的文件夹中,第二条档号ZCKD-B4.406-D30-002 页数21,把文件夹中011-031的图片放进ZCKD-B4.406-D30-002的文件夹中,依此类推……数据太多有几十万页,手工拖动太耗时间。哪位大佬有简便的方法或程序?拜托!

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

小小涩郎 发表于 2024-4-14 23:28
EXCEL倒是能写    但是你表述的也不太明确  你的文件好几万  却是3位数命名  那后面四位数文件呢
jyjjf 发表于 2024-4-15 07:08
估计不止一个文件夹,还需要其他人慢慢调教着问问
8380335 发表于 2024-4-15 09:51
本帖最后由 8380335 于 2024-4-15 09:52 编辑

不会写vba  有个方法可以试试   
1首先在excel里 创建想要的目录(也就是你的文件夹)例如你的 Excel表格中第一条档号:ZCKD-B4.406-D30-001   可以用md ZCKD-B4.406-D30-001 有多个的话也可以在Excel表格写多个 然后复制到文本文档,后缀改为.BAT  在此文件夹运行BAT 你就会得到多个文件夹。
2在excel里写复制命令copy 比如我的照片路径就是"C:\Users\administrator\Desktop\123\测试\1.jpg" (这里我需要把1-10照片全部移动到ZCKD-B4.406-D30-001可以在excel多写几行"C:\Users\administrator\Desktop\123\测试\1.jpg""C:\Users\administrator\Desktop\123\测试\2.jpg""C:\Users\administrator\Desktop\123\测试\3.jpg"等等以此类推)后面就是要移动的目录"C:\Users\Administrator\Desktop\123\测试\ZCKD-B4.406-D30-001\  最好复制在表格写好的命令 保存到文本文档 后缀还是BAT 在此目录下运行即可。这里其实可以不用表格,但是表格的好处是可以直观看到要移动的文件。

完整的命令就是移动命令就是
copy "C:\Users\administrator\Desktop\123\测试\1.jpg" "C:\Users\Administrator\Desktop\123\测试\ZCKD-B4.406-D30-001\"
copy "C:\Users\administrator\Desktop\123\测试\2.jpg" "C:\Users\Administrator\Desktop\123\测试\ZCKD-B4.406-D30-001\"

以此类推即可
kpzhy 发表于 2024-4-27 11:37
就是档案数字化里的拆分分件,很多修图软件都带有这功能的。
lizhipei78 发表于 2024-8-25 10:03
https://club.excelhome.net/thread-1681213-1-1.html
看我这个,之前有有吾爱发过,给删除了,我懒得再上传网盘了,请到上面下载,再次声明,不是推广这个论坛
luxingyu329 发表于 2024-8-25 18:25
thisxx 发表于 2024-8-26 18:56
如果没有合适的我给你现写一个吧。。。
thisxx 发表于 2024-8-26 20:51
[Python] 纯文本查看 复制代码
import pandas as pd
import os
import shutil
import sys
from natsort import natsorted

def sort_and_copy_images(excel_file, image_folder):
    df = pd.read_excel(excel_file)
    # 按照第2列和第3列内容排序
    df_sorted = df.sort_values(by=[df.columns[1], df.columns[2]])
    # 遍历每行数据
    for index, row in df_sorted.iterrows():
        folder_name = str(row[df.columns[3]])
        image_name = str(row[df.columns[0]])
        image_count = int(row[df.columns[4]])
        # 创建文件夹
        folder_path = os.path.join(os.getcwd(), folder_name)
        os.makedirs(folder_path, exist_ok=True)
        # 获取当前文件夹中根据文件名序号大小排序后的前N个影像
        images = natsorted(os.listdir(image_folder))[:image_count]
        # 拷贝影像至文件夹
        for image in images:
            image_path = os.path.join(image_folder, image)
            shutil.move(image_path, folder_path)
if __name__ == "__main__":
    if len(sys.argv) < 3:
        print("Usage: python script.py <excel_file> <image_folder>")
    else:
        excel_file = sys.argv[1]  # 外部传参指定Excel文件名
        image_folder = sys.argv[2]  # 外部传参指定图片文件夹
        sort_and_copy_images(excel_file, image_folder)



这是python代码,我试着编译发现编译后特别大而且无法独立运行,应该是由于读取excel的库造成的。
可以放到python环境下运行。您看会不会,如果不会我想办法再编译一下。
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2024-12-11 17:24

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表