import shutil
import os

from openpyxl import load_workbook
from xlutils.copy import copy
import win32com.client as win32
import xlrd

def copyfiles3p3k():
rootdir="F:\\数据备份20211108\\材料模版\\back\\1标准钢构\\3p3k\\"
sourcefile=rootdir+"\\aa.xls"
# listdir=os.listdir(rootdir)
for fileindex in range(24,41,2):
filename="3p3k"+str(fileindex)+"k.xls"
# print(filename)
file_full_name=rootdir+filename
print(file_full_name)
shutil.copyfile(sourcefile,file_full_name)

def copyfiles3p2k():
rootdir="F:\\数据备份20211108\\材料模版\\back\\1标准钢构\\3p2k\\"
sourcefile=rootdir+"\\aa.xls"
# listdir=os.listdir(rootdir)
for fileindex in range(4,41,2):
filename="3p2k"+str(fileindex)+"k.xls"
# print(filename)
file_full_name=rootdir+filename
print(file_full_name)
shutil.copyfile(sourcefile,file_full_name)

def copyfiles3p4k():
rootdir="F:\\数据备份20211108\\材料模版\\back\\1标准钢构\\3p4k\\"
sourcefile=rootdir+"\\aa.xls"
# listdir=os.listdir(rootdir)
for fileindex in range(24,41,2):
filename="3p4k"+str(fileindex)+"k.xls"
# print(filename)
file_full_name=rootdir+filename
print(file_full_name)
shutil.copyfile(sourcefile,file_full_name)

def copyfiles6p3k():
rootdir="F:\\数据备份20211108\\材料模版\\back\\1标准钢构\\6p3k\\"
sourcefile=rootdir+"\\aa.xls"
# listdir=os.listdir(rootdir)
for fileindex in range(24,41,2):
filename="6p3k"+str(fileindex)+"k双楼梯.xls"
# print(filename)
file_full_name=rootdir+filename
print(file_full_name)
shutil.copyfile(sourcefile,file_full_name)

def copyfiles6p4k():
rootdir="F:\\数据备份20211108\\材料模版\\back\\1标准钢构\\6p4k\\"
sourcefile=rootdir+"\\aa.xls"
# listdir=os.listdir(rootdir)
for fileindex in range(24,41,2):
filename="6p4k"+str(fileindex)+"k双楼梯.xls"
# print(filename)
file_full_name=rootdir+filename
print(file_full_name)
shutil.copyfile(sourcefile,file_full_name)

def read_and_modify_cell(rootdir,prefilename,sheetname,lastname,worksheet_read,rowcount):
# cell(行,列)所有单元格从0开始
wfn = int(worksheet_read.cell(6,4).value+1)
# print(wfn)#这个是得到板房K数
# 要写入的文件,找到表
path=rootdir+prefilename+str(wfn)+lastname
print(path)
rb = xlrd.open_workbook(path)
wb = copy(rb)
ws = wb.get_sheet(0)
for i in range(2, rowcount):
ws.write(i, 4, label=worksheet_read.cell(i, 4).value)
# for j in range(0, 5, 2):
# # print(str(worksheet_read.cell(i, j).value))
# ws.write(i, j, label=worksheet_read.cell(i, j).value)
wb.save(path)
# exit()

def modify_bbxls():
readfilename = 'F:\\数据备份20211108\\材料模版\\bb - 副本.xlsx'
savefilename='F:\\数据备份20211108\\材料模版\\bb - 副本.xls'
# 打开文件
workbook_read_write=load_workbook(readfilename)
# 得到要修改的表
worksheet_read_write=workbook_read_write.get_sheet_by_name('计算')
# 修改单元格
for fileindex in range(4, 41, 2):
# print(fileindex)
worksheet_read_write['b3']=str(fileindex)
# 写入模板单元格
workbook_read_write.save(readfilename)
# 把要读取的xlsx改成xls
if(os.path.isfile(savefilename)):
os.remove(savefilename)
excel=win32.gencache.EnsureDispatch('excel.application')
pro=excel.Workbooks.Open(readfilename)
pro.SaveAs(savefilename,FileFormat=56)
pro.Close(True)
excel.Application.Quit()
# 得到板房模板
sheetname=''
sheettype='3p2k'
rootdir="F:\\数据备份20211108\\材料模版\\back\\1标准钢构\\3p2k\\"
lastname='k.xls'
rowcount=0
if sheettype=='3p2k':
rowcount=27
sheetname='单层3k材料';
elif sheettype == '3p3k':
rowcount = 27
sheetname = '单层4k材料';
elif sheettype=='3p4k':
rowcount=28
sheetname = '单层4k材料';
elif sheettype=='6p3k':
rowcount=43
sheetname = '双层3k材料';
elif sheettype=='6p4k':
rowcount=44
sheetname = '双层4k材料';

worksheet_read=xlrd.open_workbook(savefilename).sheet_by_name(sheetname)
read_and_modify_cell(rootdir,sheettype,sheetname,lastname,worksheet_read,rowcount)

if __name__ == '__main__':
print('PyCharm')
modify_bbxls()
# copyfiles3p4k()
# copyfiles6p3k()
# copyfiles6p4k()
# copyfiles3p3k()
# copyfiles3p2k()

最新文章

  1. 【iOS】Alamofire库在iOS7下设置Head无效的问题
  2. IIS 301 重定向 带参数链接
  3. nginx+php 安装手册
  4. 转载:SQL Server 2008-建立分区表(Table Partition) 转载
  5. [ACM_搜索] ZOJ 1103 || POJ 2415 Hike on a Graph (带条件移动3盘子到同一位置的最少步数 广搜)
  6. 过滤器在Web开发应用------解决中文乱码
  7. SharePoint表单和工作流 - Nintex篇(三)
  8. Twisted介绍
  9. 【html】【0】开始的序言
  10. Android 监控网络状态
  11. Activiti工作流学习-----基于5.19.0版本(2)
  12. cocos2dx-lua绑定自定义c++类(二)
  13. linux中萌翻了的cowsay命令
  14. U盘制作Linux系统盘
  15. Linux Date命令学习笔记
  16. 关于AJAX使用中出现中文乱码的问题
  17. DCOMP——分散式计算
  18. 最短路(Floyd)-hdu1317
  19. 精通Linux
  20. ceph PG数量调整/PG的状态说明

热门文章

  1. Linux Yum仓库源配置
  2. 学习Kvm(七)
  3. 学习MFS(六)
  4. 数据库SQL之学习SUM总和套用条件CASE WHEN语句
  5. 攻防世界 NaNNaNNaNNaN-Batman
  6. HTTP1.1、HTTP2、HTTP3 演变
  7. DOS、DOS攻击、DDOS攻击、DRDOS攻击
  8. 【转】ng-class的用法
  9. HTML5 Performance
  10. iframe引入微信公众号文章