首页 > 编程问答 >Python 和 Excel:将数据放入另一个函数中,然后从中获取信息

Python 和 Excel:将数据放入另一个函数中,然后从中获取信息

时间:2024-08-09 03:11:24浏览次数:9  
标签:python excel

我正在尝试将温度/压力数据放入 蒸汽表 以获得过热焓数据。我已经成功地获取了数据并将其放入 Excel 文件中,然后它为我提取了焓数据。问题是,当我将温度和压力数据放入蒸汽表时,它实际上并没有进行双重插值,因此焓 (H) 值实际上从未改变

ng。我最终只得到了蒸汽数据中给出的原始值。有没有办法让它将数据放入文件中,然后按“输入”,以便它可以进行双重插值,然后我可以获取值?

这是我迄今为止的工作:

import openpyxl

def process_excel_files(input_file, process_file, output_file, data_sheet_name, process_sheet_name, result_sheet_name, input_columns, result_column, start_row=1):

# Load the workbooks

input_wb = openpyxl.load_workbook(input_file)

process_wb = openpyxl.load_workbook(process_file, data_only=True)

output_wb = openpyxl.load_workbook(output_file)

# Select the sheets

data_sheet = input_wb[data_sheet_name]

process_sheet = process_wb[process_sheet_name]

result_sheet = output_wb[result_sheet_name]

# Iterate through each row in the data_sheet

for row in range(start_row, data_sheet.max_row + 1):

# Read data points from the data_sheet

PressurePSI = data_sheet.cell(row=row, column=input_columns[0]).value #steam Pressure in PSI

TemperatureF = data_sheet.cell(row=row, column=input_columns[1]).value #Stean Temperature in F

# Convert read data points from the data_sheet

# PressureMPA=PressurePSI*0.00689476 #Steam Pressure in MPA

# TemperatureC=(TemperatureF-32)*(5/9) #Steam Temperature in C

# Input data points into the process_sheet

process_sheet.cell(row=8, column=3).value = PressurePSI

process_sheet.cell(row=8, column=4).value = TemperatureF

# Save the process_wb to update the process_sheet

process_wb.save(process_file)

# Reload the output_wb to get the updated value

process_wb = openpyxl.load_workbook(process_file)

process_sheet = process_wb[process_sheet_name]

# Retrieve the result from the process_sheet

result_value = process_sheet.cell(row=8, column=7).value # Assuming the result is in cell G8

# Write the result into the result_sheet

result_sheet.cell(row=row, column=result_column).value = result_value

# Save the output_wb to update the result_sheet

output_wb.save(output_file)

# Usage example:

input_file = 'TempPressVals.xlsx'

process_file = 'Steam_Tables.xlsx'

output_file = 'EnthalpyValues.xlsx'

data_sheet_name = 'Sheet1'

process_sheet_name = 'Sheet1'

result_sheet_name = 'Sheet1'

input_columns = [1, 2] # Columns A and B

result_column = 1 # Column C

process_excel_files(input_file, process_file, output_file, data_sheet_name, process_sheet_name, result_sheet_name, input_columns, result_column)

问题在于你只是在打开和覆盖Excel文件,但从未给Excel计算插值的机会。你需要一种方法来触发重新计算或更新Excel文件中的公式。

以下是几种方法:

1. 使用 win32com

此方法允许你直接与Excel应用程序交互,并在代码中触发计算。

import openpyxl
import win32com.client

def process_excel_files(input_file, process_file, output_file, data_sheet_name, process_sheet_name, result_sheet_name, input_columns, result_column, start_row=1):

    # ... (代码与之前相同,直到保存process_wb之前) ...

    process_wb.save(process_file)

    # 使用win32com打开Excel并计算
    excel = win32com.client.gencache.EnsureDispatch('Excel.Application')
    workbook = excel.Workbooks.Open(process_file)
    workbook.Calculate()
    workbook.Save()
    workbook.Close()
    excel.Quit()

    # ... (剩余代码与之前相同) ...

2. 使用 openpyxl data_only=False

此方法允许你在打开文件时加载公式。然后,你可以访问单元格的值,这将强制Excel计算公式。

import openpyxl

# ... (其他代码) ...

# 打开 process_file 时加载公式
process_wb = openpyxl.load_workbook(process_file, data_only=False)
process_sheet = process_wb[process_sheet_name]

# ... (输入数据) ...

# 访问单元格值以触发计算
result_value = process_sheet.cell(row=8, column=7).value 

# ... (剩余代码) ...

3. 在Excel文件中添加VBA代码

你可以在Excel文件中添加一个简单的VBA宏,该宏在工作簿打开时自动计算所有公式。然后,你可以使用Python代码打开和关闭文件,这将触发VBA宏并更新计算。

选择哪种方法?

  • 如果你需要与Excel进行更深入的交互,或者需要在计算后执行其他操作,则 win32com 是一个不错的选择。
  • 如果你只需要触发重新计算,则 openpyxl data_only=False 更简单、更轻量级。
  • 如果你希望在每次打开文件时都进行计算,则 添加VBA宏 是一个不错的选择。

请注意,这些方法都需要你的计算机上安装了Microsoft Excel。

标签:python,excel
From: 78849890

相关文章

  • Python 类型提示:显式排除无效的重载组合?
    我有一个带有两个参数的函数,每个参数都可以采用两种类型之一。四个成对组合中的三个有效,但第四个无效。我想找到一种方法来键入提示此场景,可以检查这些类型,但不一定每次调用foo()时都必须编写代码来检查无效情况。有没有办法可以改进foo()、bar()或两......
  • 我在制作 python 语音应用程序时遇到错误
    我编写了一个语音聊天应用程序代码,但是当我们运行此代码并加入语音频道时,我收到照片中的错误错误1错误2这是我的代码;客户端代码:importtkinterastkfromtkinterimportmessageboximportpyaudioimportsocketimportthreadingimporttimeHOST=......
  • pyocr,一个超酷的Python库!
    pyocr是一个用于光学字符识别(OCR)的Python库,它提供了一个简单的接口,允许开发者将图片中的文本提取出来。这个库是对Tesseract-OCR的封装,使得在Python环境中使用OCR技术变得更加便捷。如何安装pyocr首先,要使用pyocr库,您需要安装它。可以使用pip包管理工具来进......
  • pattern,一款超牛的Python库
    在程序开发中,处理文本数据和进行自然语言处理是常见需求。pattern是一个强大的Python库,专为文本分析而设计,提供了丰富的功能,包括自然语言处理、数据挖掘和网络分析等。它简单易用,让程序员能够快速实现复杂的文本处理任务。如何安装pattern在开始使用pattern库之前,首先......
  • 【Playwright+Python】系列教程(八)鉴权Authentication的使用
    写在前面还是有些絮叨的感觉,官方翻译和某些博主写那个玩楞,基本都是软件直接翻译后的产物。读起来生硬不说,甚至有的时候不到是什么意思,真的是实在不敢恭维。到底是什么意思?就是你已经登陆过一次,在Session、Cookie未失效的情况下,登录过一次后,下次就不用再走一遍登录的过程,从而缩......
  • 基于CNN-GRU-Attention混合神经网络的负荷预测方法(Python代码实现)
    ......
  • Python和AI库NumPy(二):数组创建与操作的深入探索
    目录1.数组创建1.1基本数组创建1.2使用内置函数创建数组1.3特殊数组的创建2.数组的基本操作2.1数组属性2.2数组索引和切片2.3数组的形状操作2.4数组拼接与分割3.数组的数学操作3.1基本算术操作3.2广播机制3.3线性代数运算4.高级数组操作4.1花式......
  • 纯js 导出excel表格,xmlns 方式,导出格式只能是xls
    代码onstworksheet="Sheet1";consttableHTML="<tr><td>数据1</td><td>数据2</td></tr>";constexcelHTML=`<htmlxmlns:o="urn:schemas-microsoft-com:office:office"xmlns:x="urn:s......
  • 如何为本地python共享文件网页配置公网地址实现跨网络远程访问
    文章目录前言1.本地文件服务器搭建1.1.Python的安装和设置1.2.cpolar的安装和注册2.本地文件服务器的发布2.1.Cpolar云端设置2.2.Cpolar本地设置3.公网访问测试4.结语前言本文主要介绍如何在Windows系统电脑上使用python这样的简单程序语言,在自己的电脑上搭建一个......
  • 基于YOLOv10深度学习的交通信号灯检测识别系统【python源码+Pyqt5界面+数据集+训练代
    《博主简介》小伙伴们好,我是阿旭。专注于人工智能、AIGC、python、计算机视觉相关分享研究。✌更多学习资源,可关注公-仲-hao:【阿旭算法与机器学习】,共同学习交流~......