python 表格存取方法(转)
xlwt/xlrd库 存Excel文件:(如果存储数据中有字符,那么写法还有点小小的变化)
- import xlwt
- workbook = xlwt.Workbook(encoding='utf-8')
- booksheet = workbook.add_sheet('Sheet 1', cell_overwrite_ok=True)
- #存第一行cell(1,1)和cell(1,2)
- booksheet.write(0,0,34)
- booksheet.write(0,1,38)
- #存第二行cell(2,1)和cell(2,2)
- booksheet.write(1,0,36)
- booksheet.write(1,1,39)
- #存一行数据
- rowdata = [43,56]
- for i in range(len(rowdata)):
- booksheet.write(2,i,rowdata[i])
- workbook.save('test_xlwt.xls')
读Excel文件:(同样是对于数值类型数据)
- import xlrd
- workbook = xlrd.open_workbook('D:\\Py_exercise\\test_xlwt.xls')
- print(workbook.sheet_names()) #查看所有sheet
- booksheet = workbook.sheet_by_index(0) #用索引取第一个sheet
- booksheet = workbook.sheet_by_name('Sheet 1') #或用名称取sheet
- #读单元格数据
- cell_11 = booksheet.cell_value(0,0)
- cell_21 = booksheet.cell_value(1,0)
- #读一行数据
- row_3 = booksheet.row_values(2)
- print(cell_11, cell_21, row_3)
- >>>34.0 36.0 [43.0, 56.0]
openpyxl 库 存Excel文件:
- from openpyxl import Workbook
- workbook = Workbook()
- booksheet = workbook.active #获取当前活跃的sheet,默认是第一个sheet
- #存第一行单元格cell(1,1)
- booksheet.cell(1,1).value = 6 #这个方法索引从1开始
- booksheet.cell("B1").value = 7
- #存一行数据
- booksheet.append([11,87])
- workbook.save("test_openpyxl.xlsx")
读Excel文件:
- from openpyxl import load_workbook
- workbook = load_workbook('D:\\Py_exercise\\test_openpyxl.xlsx')
- #booksheet = workbook.active #获取当前活跃的sheet,默认是第一个sheet
- sheets = workbook.get_sheet_names() #从名称获取sheet
- booksheet = workbook.get_sheet_by_name(sheets[0])
- rows = booksheet.rows
- columns = booksheet.columns
- #迭代所有的行
- for row in rows:
- line = [col.value for col in row]
- #通过坐标读取值
- cell_11 = booksheet.cell('A1').value
- cell_11 = booksheet.cell(row=1, column=1).value
原理上其实都一样,就写法上有些差别。
其实如果对存储格式没有要求的话,我觉得存成 csv文件 也挺好的:
- import pandas as pd
- csv_mat = np.empty((0,2),float)
- csv_mat = np.append(csv_mat, [[43,55]], axis=0)
- csv_mat = np.append(csv_mat, [[65,67]], axis=0)
- csv_pd = pd.DataFrame(csv_mat)
- csv_pd.to_csv("test_pd.csv", sep=',', header=False, index=False)
因为它读起来非常简单:
- import pandas as pd
- filename = "D:\\Py_exercise\\test_pd.csv"
- csv_data = pd.read_csv(filename, header=None)
- csv_data = np.array(csv_data, dtype=float)
python 表格存取方法(转)的更多相关文章
- python表格导出--xlwt的使用
xlwt可以用来导出excel表,下面介绍一下它的用法: 1. 安装xlwt模块 pip install xlwt 2. 使用xlwt模块:后端接口编写 import xlwt #导出表格接口 def ...
- Python简单爬虫入门三
我们继续研究BeautifulSoup分类打印输出 Python简单爬虫入门一 Python简单爬虫入门二 前两部主要讲述我们如何用BeautifulSoup怎去抓取网页信息以及获取相应的图片标题等信 ...
- Python SQLAlchemy --1
本文為 Python SQLAlchemy ORM 一系列教學文: SQLAlchemy 大概是目前 Python 最完整的資料庫操作的套件了,不過最令人垢病的是它的文件真的很難閱讀,如果不搭配個實例 ...
- (GoRails)ActiveRecord --explain方法:(优化你的查询)
https://gorails.com/episodes/activerecord-explain?autoplay=1 比如没有加index的查询和加了index的查询,调用数据库的速度就差5倍. ...
- Typora学习
Markdown学习总结 标题的使用格式 # 一阶标题 或者 ctrl + 1 ## 二阶标题 或者 ctrl + 2 ### 三阶标题 或者 ctrl + 3 #### 四阶标题 或者 ctrl + ...
- Typora简介
Typora是什么 Typora是一款支持实时预览的Markdown文本编辑器,拥有macOS.Windows.Linux三个平台的版本,并且完全免费. 下载地址:https://www.typora ...
- Python处理Excel表格
同事小王今天说他有一个Excel表格,表格如下,一列是姓名,一列是电话号码,总共有大概2000行数据. 有的姓名占了一行,有的占了两行,还有一些占了三行的.如下图: 他问我可不可以全部统一成一行,而且 ...
- python操作excel表格(xlrd/xlwt)
最近遇到一个情景,就是定期生成并发送服务器使用情况报表,按照不同维度统计,涉及python对excel的操作,上网搜罗了一番,大多大同小异,而且不太能满足需求,不过经过一番对源码的"研究&q ...
- python 使用openpyxl来写数据到excel表格
使用openpyxl写execl确实很方便.我先介绍用到的相关模块与函数 Workbook:工作簿模块,在内存创建一个工作簿. ExcelWriter:使用它向exel中写数据. get_column ...
随机推荐
- 用SQL将数字转换为中文数字
IF OBJECT_ID('fn_GetChnNum') IS NOT NULL BEGIN DROP FUNCTION dbo.fn_GetChnNum; END; GO CREATE FUNCTI ...
- Homestead 安装 phpMyAdmin 作为数据库管理客户端 — Laravel 实战 iBrand API 教程
简介 phpMyAdmin 是一个以PHP为基础,以Web-Base方式架构在网站主机上的MySQL的数据库管理工具,让管理者可用Web接口管理MySQL数据库.借由此Web接口可以成为一个简易方式输 ...
- C盘空间太大,分区助手减小分区大小教程
首先看一个需要缩小C盘或需要减少分区空间的一个例子:“我的电脑里C盘剩余空间为530GB,除了C盘外还有一个D盘,但D盘的空间不到30GB,另外还有两个隐藏分区,一个200MB,一个15GB.我想把C ...
- COGS 2075. [ZLXOI2015][异次元圣战III]ZLX的陨落
★★☆ 输入文件:ThefallingofZLX.in 输出文件:ThefallingofZLX.out 简单对比时间限制:1 s 内存限制:256 MB [题目描述] 正当革命如火如 ...
- python IDE--pycharm安装及使用
官网 :http://www.jetbrains.com/pycharm/ 下载community版本,免费.下载之后傻瓜式安装即可. 1 启动pycharm,选择新建项目: 设置项目路径和项目名: ...
- POJ-3009 Curling 2.0---DFS求最短路
题目链接: https://vjudge.net/problem/POJ-3009 题目大意: 问题:打冰球.冰球可以往上下左右4个方向走,只有当冰球撞到墙时才会停下来,而墙会消失.当冰球紧贴墙时,不 ...
- Netbackup-Oracle数据库恢复演练(上)
目录 第一章NBU实施内容 1 第二章 环境准备 1 2.1添加LICENSE: 1 2.2安装配置NBU客户端(linux,unix相同) 2 2.3配置并验证oracle备份脚本 3 2.4添加备 ...
- c#转载的
C#做项目时的一些经验分享 1.对于公用的类型定义,要单独抽取出来,放到单独的DLL中. 2.通过大量定义interface接口,来提高模块化程度,不同功能之间通过实现接口来面向接口编程. 3.如果项 ...
- OC#import和#include的异同
1.#import和#include相同1.1都可以用在OC程序中起到导入文件的作用1.2同样的 包含系统文件都是<>,是包本地文件都用""例如:系统文件#import ...
- JavaScript_DOM学习篇_图片切换小案例
今天开始学习DOM操作,下面写一个小案例来巩固下知识点. DOM: document object model (文档对象模型) 根据id获取页面元素 : 如: var xx = document.g ...