#!/usr/bin/python
# -*- coding: utf-8 -*-
# @Time : 2020/12/14 13:07
# @Author : cuijianzhe
# @File : xlwt.py
# @Software: PyCharm
import openpyxl
import requests
import os
import random
name = input('请输入表格名称:')
path = name + '.xlsx'
wb = openpyxl.load_workbook(path)
sheetnames = wb.sheetnames #获取文件中所有的sheet
sheetData = wb[sheetnames[0]] #第一个sheet的内容
rows_max = sheetData.max_row #最大行数
cols_max = sheetData.max_column #最大列数
ApprovalNumber = sheetData.cell(row = 1,column = 4).value
def get_case(): #获取所有表头功能
case_list = []
for cols in range(1,cols_max): #列数
cases = sheetData.cell(row=1,column=cols).value
case_list.append(cases.replace('\n\n','\n'))
return case_list
def generate_code(char):
all_char = '0123456789qazwsxedcrfvtgbyhnujmikolpQAZWSXEDCRFVTGBYHNUJIKOLP'
index = len(all_char) - 1
code = ''
for _ in range(int(char)):
num = random.randint(0,index)
code += all_char[num]
res = ''.join(code)
return res
def get_carNum():
''' 提取并添加站点名称 '''
# 第一个方法使用列表
cars_list = [] #存储车牌号
try:
for cols in range(1,cols_max):
carNum = sheetData.cell(row = 1,column = cols).value #每列的值
if carNum == '车牌号':
for rows in range(2,rows_max+1): #遍历最大行数
carnumName = sheetData.cell(row = rows,column=cols).value
if carnumName != "":
cars_list.append(carnumName)
else:
cars_list.append("空车牌号在第%s行"%(rows))
except Exception as error:
print('get车牌号错误', 'error:{}'.format(error))
return cars_list
def get_url(case_list):
url_list = []
for cols in range(1, cols_max): # 列数
datas = sheetData.cell(row=1, column=cols).value
if datas == case_list:
for rows in range(2,rows_max+1):
images_url = sheetData.cell(row=rows, column=cols).value
if images_url != "":
url_list.append(images_url.replace('\n\n','\n'))
else: #如果此单元格可能为空的话,添加自定义链接占位
url_list.append('https://file.cjzshilong.cn/pictures_file/guohui-e67e7b3b.png\n')
else:
continue
return url_list
def Download(url,car_name):
for num in range(len(car_name)):
ApprovalNumber = sheetData.cell(row=num+2, column=1).value # 订单编号
name = car_name[num] #车牌目录
name_dir = car_name[num] + '_' + ApprovalNumber #同车牌 不同订单 创建目录
list_files = os.listdir('./')
if name not in list_files:
os.mkdir(name)
os.chdir(name)
os.mkdir(name_dir)
os.chdir(name_dir)
file_list = url[num].split('\n')
with open('./统计' + name_dir + '_' + generate_code(4) + '的图片url_共计' + str(len(file_list)) + '条.txt', 'w', encoding='utf-8') as f:
f.write(url[num])
for url_car in file_list:
if url_car != '':
response = requests.get(url_car)
with open(name +'_'+ generate_code(15) + '.jpg', 'wb') as car:
car.write(response.content)
print('%s下载完毕' %name_dir)
os.chdir('../../')
else:
namedir_list = os.listdir('./' + name)
os.chdir(name)
if name_dir not in namedir_list:
os.mkdir(name_dir)
os.chdir(name_dir)
file_list = url[num].split('\n')
with open('./统计' + name_dir + '_' + generate_code(4) + '的图片url_共计' + str(len(file_list)) + '条.txt', 'w', encoding='utf-8') as f:
f.write(url[num])
for url_car in file_list:
if url_car != '':
response = requests.get(url_car)
with open(name +'_'+ generate_code(15) + '.jpg', 'wb') as car:
car.write(response.content)
print('%s下载完毕' %name_dir)
os.chdir('../../')
else:
os.chdir(name_dir)
file_list = url[num].split('\n')
with open('./统计' + name_dir + '_' + generate_code(4) + '的图片url_共计' + str(len(file_list)) + '条.txt', 'w', encoding='utf-8') as f:
f.write(url[num])
for url_car in file_list:
if url_car != '':
response = requests.get(url_car)
with open(name + '_' + generate_code(15) + '.jpg', 'wb') as car:
car.write(response.content)
print('%s下载完毕' % name_dir)
os.chdir('../../')
if __name__ == '__main__':
case_list = ['车辆正面照&车辆安全检查照','司机安全照','起始用车仪盘公里数','结束用车仪盘公里数','路桥费照片','停车费照片']
car_name = get_carNum()
for func in case_list:
url_img = get_url(func)
Download(url_img, car_name)
近期热议
推荐标签 标签
-
前端
248 引用 • 1342 回帖
前端技术一般分为前端设计和前端开发,前端设计可以理解为网站的视觉设计,前端开发则是网站的前台代码实现,包括 HTML、CSS 以及 JavaScript 等。
-
Thymeleaf
11 引用 • 19 回帖 • 413 关注
Thymeleaf 是一款用于渲染 XML/XHTML/HTML5 内容的模板引擎。类似 Velocity、 FreeMarker 等,它也可以轻易的与 Spring 等 Web 框架进行集成作为 Web 应用的模板引擎。与其它模板引擎相比,Thymeleaf 最大的特点是能够直接在浏览器中打开并正确显示模板页面,而不需要启动整个 Web 应用。
-
倾城之链
23 引用 • 66 回帖 • 189 关注
- BND
-
Webswing
1 引用 • 15 回帖 • 669 关注
Webswing 是一个能将任何 Swing 应用通过纯 HTML5 运行在浏览器中的 Web 服务器,详细介绍请看 将 Java Swing 应用变成 Web 应用 。
-
GraphQL
4 引用 • 3 回帖 • 11 关注
GraphQL 是一个用于 API 的查询语言,是一个使用基于类型系统来执行查询的服务端运行时(类型系统由你的数据定义)。GraphQL 并没有和任何特定数据库或者存储引擎绑定,而是依靠你现有的代码和数据支撑。
-
CAP
12 引用 • 5 回帖 • 660 关注
CAP 指的是在一个分布式系统中, Consistency(一致性)、 Availability(可用性)、Partition tolerance(分区容错性),三者不可兼得。
-
webpack
43 引用 • 130 回帖 • 259 关注
webpack 是一个用于前端开发的模块加载器和打包工具,它能把各种资源,例如 JS、CSS(less/sass)、图片等都作为模块来使用和处理。
-
Spark
74 引用 • 46 回帖 • 563 关注
Spark 是 UC Berkeley AMP lab 所开源的类 Hadoop MapReduce 的通用并行框架。Spark 拥有 Hadoop MapReduce 所具有的优点;但不同于 MapReduce 的是 Job 中间输出结果可以保存在内存中,从而不再需要读写 HDFS,因此 Spark 能更好地适用于数据挖掘与机器学习等需要迭代的 MapReduce 的算法。
-
Latke
71 引用 • 535 回帖 • 847 关注
Latke 是一款以 JSON 为主的 Java Web 框架。
-
Vue.js
269 引用 • 666 回帖 • 1 关注
Vue.js(读音 /vju ː/,类似于 view)是一个构建数据驱动的 Web 界面库。Vue.js 的目标是通过尽可能简单的 API 实现响应的数据绑定和组合的视图组件。
-
Solidity
3 引用 • 18 回帖 • 458 关注
Solidity 是一种智能合约高级语言,运行在 [以太坊] 虚拟机(EVM)之上。它的语法接近于 JavaScript,是一种面向对象的语言。
-
Log4j
20 引用 • 18 回帖 • 60 关注
Log4j 是 Apache 开源的一款使用广泛的 Java 日志组件。
-
链滴
203 引用 • 4025 回帖
链滴是一个记录生活的地方。
记录生活,连接点滴
- Angular
-
Unity
27 引用 • 7 回帖 • 92 关注
Unity 是由 Unity Technologies 开发的一个让开发者可以轻松创建诸如 2D、3D 多平台的综合型游戏开发工具,是一个全面整合的专业游戏引擎。
-
Shell
126 引用 • 83 回帖 • 1 关注
Shell 脚本与 Windows/Dos 下的批处理相似,也就是用各类命令预先放入到一个文件中,方便一次性执行的一个程序文件,主要是方便管理员进行设置或者管理用的。但是它比 Windows 下的批处理更强大,比用其他编程程序编辑的程序效率更高,因为它使用了 Linux/Unix 下的命令。
-
单点登录
9 引用 • 25 回帖 • 8 关注
单点登录(Single Sign On)是目前比较流行的企业业务整合的解决方案之一。SSO 的定义是在多个应用系统中,用户只需要登录一次就可以访问所有相互信任的应用系统。
-
OkHttp
16 引用 • 6 回帖 • 98 关注
OkHttp 是一款 HTTP & HTTP/2 客户端库,专为 Android 和 Java 应用打造。
-
DevOps
59 引用 • 25 回帖 • 5 关注
DevOps(Development 和 Operations 的组合词)是一组过程、方法与系统的统称,用于促进开发(应用程序/软件工程)、技术运营和质量保障(QA)部门之间的沟通、协作与整合。
-
Elasticsearch
117 引用 • 99 回帖 • 190 关注
Elasticsearch 是一个基于 Lucene 的搜索服务器。它提供了一个分布式多用户能力的全文搜索引擎,基于 RESTful 接口。Elasticsearch 是用 Java 开发的,并作为 Apache 许可条款下的开放源码发布,是当前流行的企业级搜索引擎。设计用于云计算中,能够达到实时搜索,稳定,可靠,快速,安装使用方便。
-
Markdown
173 引用 • 1559 回帖
Markdown 是一种轻量级标记语言,用户可使用纯文本编辑器来排版文档,最终通过 Markdown 引擎将文档转换为所需格式(比如 HTML、PDF 等)。
-
Wide
30 引用 • 218 回帖 • 664 关注
Wide 是一款基于 Web 的 Go 语言 IDE。通过浏览器就可以进行 Go 开发,并有代码自动完成、查看表达式、编译反馈、Lint、实时结果输出等功能。
欢迎访问我们运维的实例: https://wide.b3log.org
-
Node.js
139 引用 • 269 回帖 • 1 关注
Node.js 是一个基于 Chrome JavaScript 运行时建立的平台, 用于方便地搭建响应速度快、易于扩展的网络应用。Node.js 使用事件驱动, 非阻塞 I/O 模型而得以轻量和高效。
-
Notion
10 引用 • 80 回帖 • 1 关注
Notion - The all-in-one workspace for your notes, tasks, wikis, and databases.
-
sts
2 引用 • 2 回帖 • 260 关注
-
GitBook
3 引用 • 8 回帖
GitBook 使您的团队可以轻松编写和维护高质量的文档。 分享知识,提高团队的工作效率,让用户满意。
欢迎来到这里!
我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。
注册 关于