python炼丹师_python炼丹师_python操作excel

2023-11-23 05:59
文章标签 python excel 操作 炼丹

本文主要是介绍python炼丹师_python炼丹师_python操作excel,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

几种常用模块的使用方法

注释:Excel 2003 即XLS文件有大小限制即65536行256列,所以不支持大文件,而Excel 2007以上即XLSX文件的限制则为1048576行16384列

下面则为几种模块的使用:

61474

1.xlwt 写入xls文件内容

61474

import xlwt

book = xlwt.Workbook() # 新建工作簿

table = book.add_sheet('Over',cell_overwrite_ok=True) # 如果对同一单元格重复操作会发生overwrite Exception,cell_overwrite_ok为可覆盖

sheet = book.add_sheet('Test') # 添加工作页

sheet.write(1,1,'A') # 行,列,属性值 (1,1)为B2元素,从0开始计数

style = xlwt.XFStyle() # 新建样式

font = xlwt.Font() #新建字体

font.name = 'Times New Roman'

font.bold = True

style.font = font # 将style的字体设置为font

table.write(0,0,'Test',style)

book.save(filename_or_stream='excel_test.xls') # 一定要保存

61474

2.xlrd读取xls文件内容

61474

import xlrd

data = xlrd.open_workbook('excel_test.xls')

print(data.sheet_names()) # 输出所有页的名称

table = data.sheets()[0] # 获取第一页

table = data.sheet_by_index(0) # 通过索引获得第一页

table = data.sheet_by_name('Over') # 通过名称来获取指定页

nrows = table.nrows # 为行数,整形

ncolumns = table.ncols # 为列数,整形

print(type(nrows))

print(table.row_values(0))# 输出第一行值 为一个列表

# 遍历输出所有行值

for row in range(nrows):

print(table.row_values(row))

# 输出某一个单元格值

print(table.cell(0,0).value)

print(table.row(0)[0].value)

61474

3.综合使用python-excel三大模块完成Excel内容追加写入

61474

import xlwt,xlrd

from xlutils.copy import copy

data = xlrd.open_workbook('excel_test.xls',formatting_info=True)

excel = copy(wb=data) # 完成xlrd对象向xlwt对象转换

excel_table = excel.get_sheet(0) # 获得要操作的页

table = data.sheets()[0]

nrows = table.nrows # 获得行数

ncols = table.ncols # 获得列数

values = ["E","X","C","E","L"] # 需要写入的值

for value in values:

excel_table.write(nrows,1,value) # 因为单元格从0开始算,所以row不需要加一

nrows = nrows+1

excel.save('excel_test.xls')

61474

4.使用openpyxl写xlsx文件

61474

import openpyxl

data = openpyxl.Workbook() # 新建工作簿

data.create_sheet('Sheet1') # 添加页

#table = data.get_sheet_by_name('Sheet1') # 获得指定名称页

table = data.active # 获得当前活跃的工作页,默认为第一个工作页

table.cell(1,1,'Test') # 行,列,值 这里是从1开始计数的

data.save('excel_test.xlsx') # 一定要保存

61474

5.使用openpyxl读取xlsx文件

61474

import openpyxl

data = openpyxl.load_workbook('excel_test.xlsx') # 读取xlsx文件

table = data.get_sheet_by_name('Sheet') # 获得指定名称的页

nrows = table.rows # 获得行数 类型为迭代器

ncols = table.columns # 获得列数 类型为迭代器

print(type(nrows))

for row in nrows:

print(row) # 包含了页名,cell,值

line = [col.value for col in row] # 取值

print(line)

# 读取单元格

print(table.cell(1,1).value)

61474

6.综合使用openpyxl对Excel内容追加写入

61474

import openpyxl

data = openpyxl.load_workbook('excel_test.xlsx')

print(data.get_named_ranges()) # 输出工作页索引范围

print(data.get_sheet_names()) # 输出所有工作页的名称

# 取第一张表

sheetnames = data.get_sheet_names()

table = data.get_sheet_by_name(sheetnames[0])

table = data.active

print(table.title) # 输出表名

nrows = table.max_row # 获得行数

ncolumns = table.max_column # 获得行数

values = ['E','X','C','E','L']

for value in values:

table.cell(nrows+1,1).value = value

nrows = nrows + 1

data.save('excel_test.xlsx')

61474

7.XlsxWriter

61474

import xlsxwriter

# 1. 创建一个Excel文件

workbook = xlsxwriter.Workbook('demo1.xlsx')

# 2. 创建一个工作表sheet对象

worksheet = workbook.add_worksheet()

# 3. 设定第一列(A)宽度为20像素

worksheet.set_column('A:A',20)

# 4. 定义一个加粗的格式对象

bold = workbook.add_format({'bold':True})

# 5. 向单元格写入数据

# 5.1 向A1单元格写入'Hello'

worksheet.write('A1','Hello')

# 5.2 向A2单元格写入'World'并使用bold加粗格式

worksheet.write('A2','World',bold)

# 5.3 向B2单元格写入中文并使用加粗格式

worksheet.write('B2',u'中文字符',bold)

# 5.4 用行列表示法(行列索引都从0开始)向第2行、第0列(即A3单元格)和第3行、第0列(即A4单元格)写入数字

worksheet.write(2,0,10)

worksheet.write(3,0,20)

# 5.5 求A3、A4单元格的和并写入A5单元格,由此可见可以直接使用公式

worksheet.write(4,0,'=SUM(A3:A4)')

# 5.6 在B5单元格插入图片

worksheet.insert_image('B5','./demo.png')

# 5.7 关闭并保存文件

workbook.close()

61474

pandas

数据写入csv文件

61474

61474

importjsonimportrequestsimportpandas as pd

url= 'http://www.kfc.com.cn/kfccda/ashx/GetStoreList.ashx?op=keyword'data={'cname': '','pid': '','keyword': '上海',#查询城市

'pageIndex':'1', #显示第几页的数据

'pageSize': '100', #一页显示多少数据

}

headers={'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/75.0.3770.100 Safari/537.36'}#请求网址

response = requests.post(url=url,data=data,headers=headers)#反序列化

dic =json.loads(response.text)for i in dic["Table1"]:

storeName= i["storeName"]

addressDetail= i["addressDetail"]

pro= i["pro"]

provinceName= i["provinceName"]

cityName= i["cityName"]#构建数据结构

data={'storeName':[storeName],'addressDetail':[addressDetail],'pro':[pro],'provinceName':[provinceName],'cityName':[cityName],

}#实例化DataFrame对象

df1 = pd.DataFrame(data=data)#写入本地 不要标题|不要索引|追加的方式写入

df1.to_csv('./lagou.csv',header=False,index=False,mode='a+',encoding='gbk')print("写入成功")

View Code

读取csv文件

import pandas as pd

df_example = pd.read_csv('./lagou.csv',encoding="gbk")

print(df_example)

写入数据

61474

61474

importjsonimportxlwtimportrequests

url= 'http://www.kfc.com.cn/kfccda/ashx/GetStoreList.ashx?op=keyword'data={'cname': '','pid': '','keyword': '上海',#查询城市

'pageIndex':'1', #显示第几页的数据

'pageSize': '100', #一页显示多少数据

}

headers={'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/75.0.3770.100 Safari/537.36'}#请求网址

response = requests.post(url=url,data=data,headers=headers)#反序列化

dic =json.loads(response.text)

title= ["storeName","addressDetail","pro","provinceName","cityName"]

li=[]#获取数据

for i in dic["Table1"]:

storeName= i["storeName"]

addressDetail= i["addressDetail"]

pro= i["pro"]

provinceName= i["provinceName"]

cityName= i["cityName"]

li.append([storeName,addressDetail,pro,provinceName,cityName])#新建一个excel对象

wbk =xlwt.Workbook()#添加一个名为stu的sheet页

sheet = wbk.add_sheet('stu')#写入表头

for i inrange(len(title)):#从0行i列写入标题

sheet.write(0,i,title[i])#写入数据

for i inrange(len(li)):#如果不是表头的话

if i!=0:#循环写入数据

for j inrange(len(title)):

sheet.write(i,j,li[i][j])

wbk.save('szz.xls')print("下载成功")

爬虫演示

爬虫演示

61474

这篇关于python炼丹师_python炼丹师_python操作excel的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/415874

相关文章

python: 多模块(.py)中全局变量的导入

文章目录 global关键字可变类型和不可变类型数据的内存地址单模块(单个py文件)的全局变量示例总结 多模块(多个py文件)的全局变量from x import x导入全局变量示例 import x导入全局变量示例 总结 global关键字 global 的作用范围是模块(.py)级别: 当你在一个模块(文件)中使用 global 声明变量时,这个变量只在该模块的全局命名空

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

【机器学习】高斯过程的基本概念和应用领域以及在python中的实例

引言 高斯过程(Gaussian Process,简称GP)是一种概率模型,用于描述一组随机变量的联合概率分布,其中任何一个有限维度的子集都具有高斯分布 文章目录 引言一、高斯过程1.1 基本定义1.1.1 随机过程1.1.2 高斯分布 1.2 高斯过程的特性1.2.1 联合高斯性1.2.2 均值函数1.2.3 协方差函数(或核函数) 1.3 核函数1.4 高斯过程回归(Gauss

【学习笔记】 陈强-机器学习-Python-Ch15 人工神经网络(1)sklearn

系列文章目录 监督学习:参数方法 【学习笔记】 陈强-机器学习-Python-Ch4 线性回归 【学习笔记】 陈强-机器学习-Python-Ch5 逻辑回归 【课后题练习】 陈强-机器学习-Python-Ch5 逻辑回归(SAheart.csv) 【学习笔记】 陈强-机器学习-Python-Ch6 多项逻辑回归 【学习笔记 及 课后题练习】 陈强-机器学习-Python-Ch7 判别分析 【学

nudepy,一个有趣的 Python 库!

更多资料获取 📚 个人网站:ipengtao.com 大家好,今天为大家分享一个有趣的 Python 库 - nudepy。 Github地址:https://github.com/hhatto/nude.py 在图像处理和计算机视觉应用中,检测图像中的不适当内容(例如裸露图像)是一个重要的任务。nudepy 是一个基于 Python 的库,专门用于检测图像中的不适当内容。该

pip-tools:打造可重复、可控的 Python 开发环境,解决依赖关系,让代码更稳定

在 Python 开发中,管理依赖关系是一项繁琐且容易出错的任务。手动更新依赖版本、处理冲突、确保一致性等等,都可能让开发者感到头疼。而 pip-tools 为开发者提供了一套稳定可靠的解决方案。 什么是 pip-tools? pip-tools 是一组命令行工具,旨在简化 Python 依赖关系的管理,确保项目环境的稳定性和可重复性。它主要包含两个核心工具:pip-compile 和 pip

HTML提交表单给python

python 代码 from flask import Flask, request, render_template, redirect, url_forapp = Flask(__name__)@app.route('/')def form():# 渲染表单页面return render_template('./index.html')@app.route('/submit_form',

动手学深度学习【数据操作+数据预处理】

import osos.makedirs(os.path.join('.', 'data'), exist_ok=True)data_file = os.path.join('.', 'data', 'house_tiny.csv')with open(data_file, 'w') as f:f.write('NumRooms,Alley,Price\n') # 列名f.write('NA

线程的四种操作

所属专栏:Java学习        1. 线程的开启 start和run的区别: run:描述了线程要执行的任务,也可以称为线程的入口 start:调用系统函数,真正的在系统内核中创建线程(创建PCB,加入到链表中),此处的start会根据不同的系统,分别调用不同的api,创建好之后的线程,再单独去执行run(所以说,start的本质是调用系统api,系统的api

Java IO 操作——个人理解

之前一直Java的IO操作一知半解。今天看到一个便文章觉得很有道理( 原文章),记录一下。 首先,理解Java的IO操作到底操作的什么内容,过程又是怎么样子。          数据来源的操作: 来源有文件,网络数据。使用File类和Sockets等。这里操作的是数据本身,1,0结构。    File file = new File("path");   字