zoukankan      html  css  js  c++  java
  • 修改Excel脚本

    批量修改Excel
    
    TODO: 批量修改Excel
    
    功能: 将图片防止在本地,读取excel数据,拆分数据之后根本地照片名称对比,然后上传服务器,创建新得excel。
    
    #!/usr/bin/python
    # -*- coding: UTF-8 -*-
    __author__ = 'YongCong Wu'
    # @Time    : 2019/6/14 16:18
    # @Email   :  : 1922878025@qq.com
    
    
    import requests, os, sys, xlwt
    import pandas as pd
    
    
    reload(sys)
    sys.setdefaultencoding('utf8')
    
    ExcelPath = 'E:ExcelImgDrive\'
    DirPath = 'E:80\' + "files\"
    read_excel_list = []
    read_img_path_list = []
    presence_img = None
    
    
    # 读取excel
    def excel_list(file_path):
        df = pd.read_excel(ExcelPath + file_path, names=None)
        df_li = df.values.tolist()
        for i in df_li:
            split_str = i[1].split("/")[-1]
            read_excel_list.append(split_str)
        print u"Excel 读取完毕..........."
    
    
    # 读取图片
    def red_img(dir_path):
        for i in os.listdir(dir_path):
            if i.endswith('jpg') or i.endswith("png"):
                read_img_path_list.append(i)
        print u"Image 读取完毕..........."
    
    
    # 两个list对比
    def if_list(excel_list, img_list):
        filter_List = [x for x in excel_list if x in img_list]
        print u"图片对比完毕..........."
        butong = [y for y in (excel_list + img_list) if y not in filter_List]
        print u"存在的个数:   {0}".format(len(filter_List))
        print u"不存在的个数:   {0}".format(len(butong))
        report_excel_data = []
        num = 0
        for i in filter_List:
            ret = update_file(DirPath + i)
            num += 1
            report_excel_data.append([num, "https://wuyongcong.com/files/"+ret[0], ret[1] ])
            print u"当前上传成功{0}张照片".format(num)
        workbook = xlwt.Workbook(encoding='utf-8')
        booksheet = workbook.add_sheet("Sheet 1", cell_overwrite_ok=True)
        for i, row in enumerate(report_excel_data):
            for j, col in enumerate(row):
                booksheet.write(i, j, col)
        workbook.save(u'司机身份证正面.xls')
        print u"导出Excel完成............."
    
    
    # 上传图片, 返回地址保存Excel
    def update_file(name):
        url = '上传图片服务器地址'
        file_s = {'file': open(name, 'rb')}
        options = {'output': 'json', 'path': '', 'scene': 'default'}
        try:
            r = requests.post(url, files=file_s, data=options)
            res = r.json()
            split_str = name.split("\")[-1]
            return split_str, res['url']
        except Exception as er:
            print(er)
    
    
    
    excel_list('CardPhotoPath.xlsx')
    red_img(DirPath)
    if_list(read_excel_list, read_img_path_list)
    

      

  • 相关阅读:
    【知识整理】这可能是最好的性能优化教程(一)
    【工作感悟】Android 开发者,如何提升自己的职场竞争力?
    MySql 主从复制
    MyCat 介绍、分片规则、调优的内容收集
    MyCat 安装部署,实现数据库分片存储
    [转]Activemq管理和基本介绍
    [转]ActiveMQ 即时通讯服务 浅析
    Redis 3.0集群 Window搭建方案
    【转】史上最全的“大数据”学习资源整理
    【转】【漫画解读】HDFS存储原理
  • 原文地址:https://www.cnblogs.com/wuyongcong/p/11064332.html
Copyright © 2011-2022 走看看