python3中关于excel追加写入格式被覆盖问题

关于python3中的追加写入excel问题,这个问题坑了我几小时,其实加一个参数即可。
因为之前有写好的excel,想追加写入,但是写入后却只有写入后的单元格格式,之前写的完全消失。

以下是我的代码

这代码可以用是我做的一个爬虫维护项目:

def times():
    User_Agent = 'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/54.0.2840.99 Safari/537.36'
    headers = {
        'User-Agent': User_Agent
    }
    search_url = 'https://www.cnss.com.cn/u/cms/www/indexJson/bdi_month.json?v=1577414941357'
    request = urllib.request.Request(search_url, headers=headers)
    response = urllib.request.urlopen(request)
    content = response.read().decode('utf-8')
    content = ''.join(content)
    # print(content)
    # index = re.findall('index":"(.*?)"', content)  # 获取指数
    date = re.findall('date":"(.*?)"', content)  # 获取时间
    time = []
    i = 0
    start_date = date[0].replace('.', '年')
    start_date.replace('.', '月')
    end_date = date[-1].replace('.', '年')
    end_date.replace('.', '月')
    # print(index,date,start_date,end_date)
    for j in range(int(len(date) / 1)):
        temp = date[i:i + 1]
        i += 1
        time.append(temp)
        hears = start_date + '日' + '——' + end_date + '日' + '嘻嘻嘻'
        title=['交易日期','干散货指数(BDI)','海岬型指数(BCI)','巴拿马型指数(BPI)','超灵便型船运价指数(BSI)','灵便型船指数(BHSI)']
        sheet1.write_merge(0, 0+0,0,0+5, hears, style)
        for ti in range(len(title)):
            sheet1.write(1, ti+0, title[ti], style)
        for x in range(len(time)):
            for y in range(len(time[x])):
                sheet1.write(x + 2, 0, time[x][y], style)
        f.save('你想放的路径.xls')

上面的代码还是可以继续使用

标题xlwt的缺陷:

xlwt只能创建一个全新的excel文件,然后对这个文件进行写入内容以及保存。但是大多数情况下我们希望的是读入一个excel文件,然后进行修改或追加,这个时候就需要xlutils了。

xlutils的简单使用:

接下来的部分就是关键所在了
formatting_info=True这个参数能保留原excel格式

def write_excel_xls_append(path, value,u):
    index = len(value)  # 获取需要写入数据的行数
    workbook = xlrd.open_workbook('./result/30波罗的海干散货运价指数.xls',formatting_info=True)  # 打开工作簿
    sheets = workbook.sheet_names()  # 获取工作簿中的所有表格
    worksheet = workbook.sheet_by_name(sheets[0])  # 获取工作簿中所有表格中的的第一个表格
    rows_old = worksheet.ncols  # 获取表格中已存在的数据的行数
    new_workbook = copy(workbook)  # 将xlrd对象拷贝转化为xlwt对象
    styleS = xlwt.XFStyle()
    alignment = xlwt.Alignment()
    alignment.horz = xlwt.Alignment.HORZ_CENTER
    alignment.vert = xlwt.Alignment.VERT_CENTER
    styleS.alignment = alignment
    new_worksheet = new_workbook.get_sheet(0)  # 获取转化后工作簿中的第一个表格
    for i in range(0, index):
        for j in range(0, len(value[i])):
            new_worksheet.write(i+2, u+1, value[i][j],styleS)  # 追加写入数据,注意是从i+rows_old行开始写入
    new_workbook.save(path)  # 保存工作簿

然后你就会发现你的excel简直完美~~~

  • 6
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
可以使用Python的openpyxl库来实现向已有数据的Excel的空行追加数据,不覆盖原数据的功能。下面是一份示例代码,供参考: ```python import openpyxl # 打开已有的Excel表格 workbook = openpyxl.load_workbook('example.xlsx') # 选择要操作的工作表 worksheet = workbook['Sheet1'] # 获取该工作表最后一行的行数 last_row = worksheet.max_row # 将要写入的数据存储在一个列表 new_data = ['new data 1', 'new data 2', 'new data 3'] # 追加数据到新的空行 for i in range(len(new_data)): worksheet.cell(row=last_row+i+1, column=1).value = new_data[i] # 保存修改后的Excel表格 workbook.save('example.xlsx') ``` 在上面的示例代码,我们首先使用openpyxl库打开了一个名为`example.xlsx`的Excel表格,并选择了其名为`Sheet1`的工作表。然后,我们使用`max_row`属性获取该工作表最后一行的行数,并将要写入的新数据存储在一个列表`new_data`。 接下来,我们使用一个for循环来遍历新数据列表,将每个元素写入一个新的空行。具体地,我们使用`cell()`方法来获取对应单元格的对象,并使用`value`属性设置其值。其,`row`参数表示要写入的行号,`column`参数表示要写入的列号,这里我们只写入了第1列。 最后,我们使用`save()`方法将修改后的Excel表格保存到文件。这样,就实现了向已有数据的Excel的空行追加数据,不覆盖原数据的功能。
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值