表格模板:

目的将卡片1到卡片5的所有数据组合起来到一个单元格中如下入F列中(工作中为了避免手动复制粘贴),其余不变,因为数据太多  自己一个一个复制工作效率太低,所以写这个脚本是为了方便自己
有需要的也可进行修改后使用。
运行结果如下:

反过来 以“;”分隔上图F列  结果显示为 卡片1 卡片2 卡片3 的结果
def readExcelDataByName(filename, sheetName):
'''读取Excel文件和表名'''
wb = xlrd.open_workbook(filename)
# sheet=data.sheet_by_index(0)#通过索引顺序获取,0表示第一张表
# sheets = data.sheet_names()#获取文件中的表名
sheet = wb.sheet_by_name(sheetName)
ncols = sheet.ncols
# 获取行数
nrows = sheet.nrows
print("nrows %d, ncols %d" % (nrows, ncols))
row_list = []
work_book = xlwt.Workbook("11.xls")
sheet1 = work_book.add_sheet("Sheet1")
k = 1
for j in range(1, nrows):
# 获取单元格
for i in range(6, ncols):
data = sheet.cell_value(j, i)
if data == "":
continue
else:
row_list.append(str(k) + "." + data + "\n")
k = k + 1
# print(row_list) sheet1.write(j, 5, row_list)
row_list.clear()
k = 1
for m in range(0,7):
for n in range(0,5):#列
data=sheet.cell_value(m, n)
sheet1.write(m, n, data)
if os.path.exists("11.xls"):
os.remove("11.xls")
work_book.save("11.xls")
else:
work_book.save("11.xls")
if __name__ == '__main__':
readExcelDataByName('模板.xlsx', 'Sheet1')

  

#!user/bin/env python
# coding=utf-
# @Author : Dang
# @Time : // :
# @Email : @qq.com
# @File : Test_SplitExcel.py
# @Description:对excel单元格已;进行分隔,完成后需要对
import xlrd
import xlwt
import os
import re def readExcelDataByName(filename, sheetName, num,save_filename):
"""
:param filename:输入文件路径和名字+后缀
:param sheetName:输入表名
:param num:输入要分隔的列
:param save_filename:要保存的文件名称
""" wb = xlrd.open_workbook(filename)
# sheet=data.sheet_by_index()#通过索引顺序获取,0表示第一张表
# sheets = data.sheet_names()#获取文件中的表名
sheet = wb.sheet_by_name(sheetName)
ncols = sheet.ncols
# print(ncols)
# 获取行数
nrows = sheet.nrows
print("nrows %d, ncols %d" % (nrows, ncols))
row_list = []
work_book = xlwt.Workbook()
sheet1 = work_book.add_sheet(sheetName[:-], cell_overwrite_ok=True)
for m in range(, nrows):
for n in range(, num): # 列
data_init = sheet.cell_value(m, n)
sheet1.write(m, n, data_init)
k=
for m in range(, nrows):
data = sheet.cell_value(m, num)
row_list = re.split(";", data.replace("\n", ""))
for n in range(, len(row_list)): # 列
sheet1.write(m, n + num, row_list[n]) # 从第6列写入
k=k+len(row_list)
# print(m)
# print(row_list)
row_list.clear()
# print(k-nrows) print("大约有 %d个用例,此处只做大概统计,具体需要根据实际情况减去相应值" %(k-nrows)) for i in range(num, ncols):
data_add = sheet.cell_value(, i)
# print(kapian)
sheet1.write(, i, data_add)
if os.path.exists(save_filename + sheetName + ".xls"):
os.remove(save_filename + sheetName + ".xls")
work_book.save(save_filename + sheetName + ".xls")
else:
work_book.save(save_filename + sheetName + ".xls")
print("转换完成,请查看 %s%s.xls的文档。" %(save_filename,sheetName))
if __name__ == '__main__':
"""
:param filename:输入文件路径和名字+后缀
:param sheetName:输入表名
:param num:输入要分隔的列
:param save_filename:要保存的文件路径和名称,要保存文件名会和表名自动组合形成新的文件 如:分隔结果文档Sheet1.xls
"""
readExcelDataByName('11.xls', 'Sheet1', ,"结果文档")

python 将表格多个列数据放到同一个单元格中的更多相关文章

  1. JS遍历表格获取每行数据及每个单元格数据

    /** * 遍历表格获取每行数据及每个单元格数据 * @param tableID 表格ID */ function GetTable(tableID) { var milasUrl = {};//新 ...

  2. Swift - 可编辑表格样例(可直接编辑单元格中内容、移动删除单元格)

    (本文代码已升级至Swift3)   本文演示如何制作一个可以编辑单元格内容的表格(UITableView). 1,效果图 (1)默认状态下,表格不可编辑,当点击单元格的时候会弹出提示框显示选中的内容 ...

  3. python实例:从excel读取股票代码,爬取股票信息写到代码后面的单元格中

    关键词:爬虫.python.request.接口.excel处理 思路: 1.首先准备好excel文档,把股票代码事先编辑进去. 2.脚本读取文档,依次读出股票代码到指定站点发起请求获取股票信息 3. ...

  4. Aspose.Cells 首次使用,用到模版填充数据,合并单元格,换行

    Aspose.Cells 首次使用,用到模版填充数据,合并单元格,换行 模版格式,图格式是最简单的格式,但实际效果不是这种,实际效果图如图2 图2 ,注意看红色部分,一对一是正常的,但是有一对多的订单 ...

  5. EXCEL表格单元格中包含数字英文和汉字,如何自动去掉汉字,保留英文和数字

    EXCEL表格单元格中包含数字英文和汉字,如何自动去掉汉字,保留英文和数字 Function 求数字和字母(对象 As String) '在文本与数字混杂中提取数字和字母   Dim myReg    ...

  6. Excel催化剂开源第15波-VSTO开发之DataTable数据导出至单元格区域

    上篇提到如何从Excel界面上拿到用户的数据,另外反方向的怎样输出给用户数据,也是关键之处. VSTO最大的优势是,这双向的过程中,全程有用户的交互操作. 而一般IT型的程序,都是脱离用户的操作,只能 ...

  7. 将Word表格中单元格中的文字替换成对应的图片

    示例 原文件结构: 替换后文档结构: 软件截图: 代码: using System;using System.Collections.Generic;using System.ComponentMod ...

  8. excel表格中打开可以显示整个表格但是打印却只能打印一个单元格

    excel表格中打开可以显示整个表格但是打印却只能打印一个单元格 如下图显示 解决办法 2007 版菜单栏上 ----->页面布局----->打印区域----->取消打印.即可正常. ...

  9. 雷林鹏分享:jQuery EasyUI 数据网格 - 合并单元格

    jQuery EasyUI 数据网格 - 合并单元格 数据网格(datagrid)经常需要合并一些单元格.本教程将向您展示如何在数据网格(datagrid)中合并单元格. 为了合并数据网格(datag ...

随机推荐

  1. hutool http+天气预报

    中国天气接口:http://www.weather.com.cn/data/sk/地址.html,只显示当天. sojson接口:http://t.weather.sojson.com/api/wea ...

  2. spring boot 系统启动时运行代码(1)-@PostConstruct

    Application.java import org.springframework.boot.SpringApplication; import org.springframework.boot. ...

  3. 利用划分树求解整数区间内第K大的值

    如何快速求出(在log2n的时间复杂度内)整数区间[x,y]中第k大的值(x<=k<=y)? 其实我刚开始想的是用快排来查找,但是其实这样是不行的,因为会破坏原序列,就算另外一个数组来存储 ...

  4. MongoDB + express + node + bootstrap 搭建多人博客

    这篇博客讲述如何搭建一个多人博客,需要一定的基础知识,用于思路整理和备忘. 第一步: 新建文件夹 blog ,结构如下: bin --- 可执行二进制文件,最终的启动接口. models --- 存储 ...

  5. 06-spring常见的连接池配置

    1 准备工作 首先,我们准备jdbc属性文件 database.properties,用于保存连接数据库的信息,利于我们在配置文件中使用. 只要在applicationContext.xml(Spri ...

  6. Tomcat安装和配置过程

    tomcat的下载.配置.启动方法.网上教程乱七八糟,还是自己mark一下备用吧. 一.官网下载Tomcat的压缩包 Tomcat是Apache软件基金会的一个开源项目.登录Apache官网即可找到下 ...

  7. Ubuntu瞎胡搞

    ubutnu的几个必不可少的软件: 1.Guake,超级方便的终端 2.Unity tweak tool 3.VLC,本地视频播放器 4.MyPint,简单画图软件 5.GIMP,PS工具 Subli ...

  8. CI模板中php脚本的使用

    今天偶然发现,在CI的模板中能够直接使用CI自带的函数,并且可以直接调用controller里面的属性.案例: 控制器: public function test(){ $this->a = ' ...

  9. Win2D 官方文章系列翻译 - 与 Direct2D 互操作

    本文为个人博客备份文章,原文地址: http://validvoid.net/win2d-interop-with-direct2d/ Win2D 作为 Direct2D 的上层实现,支持与其进行双向 ...

  10. pm2的的常用命令及用法

    使用pm2启动静态文件服务器的方法如下: pm2 serve path port pm2 serve . 9001 这样就可以把当前文件夹下的静态文件跑起来了,而且端口号是9001, 同样也支持进阶的 ...