一、系统性学习

对于操作Excel,需要Xlrd/xlwt这两个模块,下面推荐出系统性学习的网址:

python操作Excel读写--使用xlrd

官方文档

Python 使用 Xlrd/xlwt 操作 Excel

用Python读写Excel文件

二、实战

帮朋友处理一个excel,幸好数据量不大,几万条数据。需求如下:

指定选取三列然后挑选出同时满足>=1或者同时<=-1的 将其所有数据存入新的csv表格中

程序如下:

#!/usr/bin/env python
# -*- coding: utf-8 -*-
# @Date    : 2014-04-10 21:47:56
# @Function: 指定选取三列然后挑选出同时满足>=1或者同时<=-1的 将其所有数据存入新的csv表格中
# @Author  : BeginMan

import os
import string
import xlrd
import xlwt

def get_data():
    """获取excel数据源"""
    file = r'C:\Users\Administrator\Desktop\pytool\xlrd\initial_log_data.xls'           # 改成自己的路径
    filepath = raw_input(u'请将xls文件路径粘贴进去,如果程序里已经指定了文件则按Enter键继续:')
    is_valid = False            # 验证文件
    try:
        filepath = [file, filepath][filepath != '']
        print filepath
        # 判断给出的路径是不是xls格式
        if os.path.isfile(filepath):
            filename = os.path.basename(filepath)
            if filename.split('.')[1] == 'xls':
                is_valid = True
        data = None
        if is_valid:
            data = xlrd.open_workbook(filepath)
    except Exception, e:
        print u'你操作错误:%s' %e
        return None
    return data

def handle_data():
    """处理数据"""
    data = get_data()
    if data:
        col_format = ['B', 'C', 'D']        # 指定的列
        inp = raw_input(u'请选择指定的三列,用逗号分隔,默认的是B,C,D(英文逗号,不区分大小写),如果选择默认则按Enter键继续:\n')
        try:
            inp = inp.split(',')
            col_format = [col_format,inp][len([i for i in inp if i in string.letters]) == 3]
            col_format = [i.upper() for i in col_format]                    # 转换成大写
            table = data.sheet_by_index(0)                                  # 选取第一个工作区
            nrows = table.nrows                                             # 行数
            ncols = table.ncols                                             # 列数
            str_upcase = [i for i in string.uppercase]                      # 所有大写字母
            i_upcase = range(len(str_upcase))                               # 对应的数字
            ncols_dir = dict(zip(str_upcase,i_upcase))                      # 格式成字典
            col_index = [ncols_dir.get(i) for i in col_format]              # 获取指定列所对应的索引

            # 选取的三列是否同时满足 >=1或者同时<=-1
            print u'正在检索中……'
            count = 0
            result = []
            for i in xrange(nrows):
                cell_0 = table.cell(i,col_index[0]).value
                cell_1 = table.cell(i,col_index[1]).value
                cell_2 = table.cell(i,col_index[2]).value
                if (cell_0>=1 and cell_1>=1 and cell_2>=1) or (cell_0<=-1 and cell_1<=-1 and cell_2<=-1):
                    result.append(table.row_values(i))      # 将符合要求的一行添加进去
                    count += 1
            print u'该文件中共%s行,%s列,其中满足条件的共有%s条数据' %(nrows, ncols, count)
            print u'正在写入数据……'
            col_name = col_format[0]+col_format[1]+col_format[2]
            if write_data(result, col_name):
                print u'写入成功!'
        except Exception, e:
            print u'你操作错误:%s' %e
            return None
    else:
        print u'操作失败'
        return None

def write_data(data, name):
    """写入数据,data为符合条件的数据列表,name表示指定的哪三个列,以此命名"""
    file = xlwt.Workbook()
    table = file.add_sheet(name,cell_overwrite_ok=True)
    l = 0   # 表示行
    for line in data:
        c = 0   # 表示一行下的列数
        for col in line:
            table.write(l,c,line[c])
            c += 1
        l += 1
    defatul_f = r'C:\Users\Administrator\Desktop\pytool\xlrd'       # 默认路径
    f = raw_input(u'请选择保存文件的路径:按回车跳过:')
    f_name = r'\%s.xls' % name
    filepath = [defatul_f+f_name, f+f_name][f != '']
    file.save(filepath)
    return True

def main():
    handle_data()

if __name__ == '__main__':
    main()

运行结果如下:

源数据

处理后的数据

Python操作Excel的更多相关文章

  1. python操作excel表格(xlrd/xlwt)

    最近遇到一个情景,就是定期生成并发送服务器使用情况报表,按照不同维度统计,涉及python对excel的操作,上网搜罗了一番,大多大同小异,而且不太能满足需求,不过经过一番对源码的"研究&q ...

  2. Python操作excel(xlrd和xlwt)

    Python操作excel表格有很多支持的库,例如:xlrd.xlwt.openpyxl.win32com,下面介绍使用xlrd.xlwt和xlutils模块这三个库不需要其他的支持,在任何操作系统上 ...

  3. Python操作excel表格

    用Python操作Excel在工作中还是挺常用的,因为毕竟不懂Excel是一个用户庞大的数据管理软件 注:本篇代码在Python3环境下运行 首先导入两个模块xlrd和xlwt,xlrd用来读取Exc ...

  4. Python 利用Python操作excel表格之openyxl介绍Part2

    利用Python操作excel表格之openyxl介绍 by:授客 QQ:1033553122 欢迎加入全国软件测试交流qq群(群号:7156436) ## 绘图 c = LineChart()    ...

  5. Python 利用Python操作excel表格之openyxl介绍Part1

    利用Python操作excel表格之openyxl介绍 by:授客 QQ:1033553122 欢迎加入全国软件测试交流qq群(群号:7156436),免费获取以下性能监控工具(类似Nmon精简版) ...

  6. 【转】python操作excel表格(xlrd/xlwt)

    [转]python操作excel表格(xlrd/xlwt) 最近遇到一个情景,就是定期生成并发送服务器使用情况报表,按照不同维度统计,涉及python对excel的操作,上网搜罗了一番,大多大同小异, ...

  7. Python 利用Python操作excel表格之xlwt介绍

    利用Python操作excel表格之xlwt介绍   by:授客 QQ:1033553122 直接上代码   案例1 #!/usr/bin/env python # -*- coding:utf-8 ...

  8. Python 操作Excel之通过xlutils实现在保留原格式的情况下追加写入数据

    在Python操作Excel 的模块有 xlrd.xlwt.xlutils等. xlrd:读取Excel文件数据 xlwt:写入Excel 数据,缺点是Excel格式无法复用,为了方便用户,写入的话, ...

  9. python基础(六)python操作excel

    一.python操作excel,python操作excel使用xlrd.xlwt和xlutils模块,xlrd模块是读取excel的,xlwt模块是写excel的,xlutils是用来修改excel的 ...

随机推荐

  1. Java.web-application-development-environments-for-macosx

    Java Web Application开发 1 下载需要的软件 使用的软件并没有采用最新的版本,只是采用了次新版本. 1.1 下载Eclipse的jee版本 eclipse-jee-luna-SR2 ...

  2. iOS 1 到 iOS 10 ,我都快老了

    iOS 1:iPhone诞生 虽然很难想像,但初代iPhone在问世时在功能方面其实远远落后于那时的竞争对手,比如Windows Mobile.Palm OS.塞班.甚至是黑莓.它不支持3G.多任务. ...

  3. [MongoDB]Mongodb攻略

    -------------------------------------------------------------------------------------------- [基础] 1. ...

  4. css3之background-clip与background-origin的区别

    background-clip 规定背景的绘制区域. 3 background-origin 规定背景图片的定位区域. 3 background-size 规定背景图片的尺寸. 3 backgroun ...

  5. php pdo预处理语句与存储过程

    很多更成熟的数据库都支持预处理语句的概念.什么是预处理语句?可以把它看作是想要运行的 SQL 的一种编译过的模板,它可以使用变量参数进行定制.预处理语句可以带来两大好处: 1.查询仅需解析(或预处理) ...

  6. MVC之校验

    MVC校验 首先要在Models中创建几个属性 例子:Id.UserName.Age属性.然后创建控制器,然后添加一个试图,选择强类型,选择支架模板Create生成页面,然后将所有控件改为TextBo ...

  7. EXCEL某列长度超过255个字符导入SQL SERVER的处理方法

    问题描述: [Excel 源 [1]] 错误: 输出“Excel 源输出”(9) 上的 输出列“Description 3”(546) 出错.返回的列状态是:“文本被截断,或者一个或多个字符在目标代码 ...

  8. 关于mysql占用CPU过高,问题解决

    使用SHOW PROCESSLIST 查看 原因: 使用了 一个触发器 不断的去删除日志,保证每个用户的日志只有10条 去掉之后,CPU使用率从97% 降到了 %. 利用show columns fr ...

  9. VS2012 生成事件

    在一个解决方案中有多个项目的时候,我们常需要拷贝一些文件,dll到指定的目录下,或者遇到com组件还需要提前注册dll,这个就需要用到VS的生成事件. 一.位置: 项目-->右键-->属性 ...

  10. 简洁清新的box样式

    小菜今天偶然打开了腾讯公益,本来是冲着公益活动去的,没想到腾讯公益界面做的还不错,索性把它的box样式剽窃了下来. 个人觉得腾讯的东西普遍比较精致,就拿页面来说,每一个细节都把握的很到位,例如取色,看 ...