Python读取Microsoft Access Database

2023-05-16

公司有一个小零件进出库管理系统,数据库是使用Microsoft Access Database,因长期存储会有生锈问题,导致零件报废。因此基于原数据的进库出库在库数据,做一个python脚本,可以查询在库零件指定存储日期之前还有多少库存。第一步就是使用python读access。

使用pypyodbc模块,需要根据电脑环境,python版本,选择对应的AccessDatabaseEngine文件安装,注意是32位还是64位。都安装完后,执行语句如下:
遇到问题如下:

  1. cur.fetchall()得到的是元组的列表,可以直接建立DataFrame
  2. 使用cur.execute(“SELECT * FROM Tablename”),Tablename是数据库中的表格名称,可以多次打开不同表格,读取数据。
  3. cur.fetchall()如果遇到数据是科学计数法,0.1E-02,其中会报错显示str 数据类型不能转换位float数据类型,原因是有b’E-2’, 这个我还没有找到解决方法,能够直接识别科学计数法,只能先替换数据库中所有出现科学技术法的地方。这个问题求大神支招。

这只是程序的一部分,其它地方因为都是数据清洗和计算,在此就不列出了。

import numpy as np
import pandas as pd
import pypyodbc
# 连接Access数据库,读取Stock,InStock,Out数据
connStr = 'Driver={Microsoft Access Driver (*.mdb,*.accdb)};DBQ=C:\\BOSCH.mdb' 
#同样是绝对路径
conn = pypyodbc.win_connect_mdb(connStr)
cur = conn.cursor()
cur.execute("SELECT * FROM Stock")
# cur.fetchall()得到的是元组的列表,可以直接建立DataFrame
# 使用cur.execute("SELECT * FROM Tablename"),Tablename是数据库中的表格名称,可以多次打开不同表格,读取数据。
# cur.fetchall()如果遇到数据是科学计数法,0.1E-02,其中会报错显示str 数据类型不能转换位float数据类型,原因是有b'E-2'
stock = pd.DataFrame(cur.fetchall(),columns = ['ID','Rawmaterial','Partnumber','Thickness','Count',
                   'FZ1','FZ2','FZ3','FZ4','XM1','XM2','XM3','XM4'])
cur.execute("SELECT * FROM InStock")
instock = pd.DataFrame(cur.fetchall(),columns = ['ID','Barcode','Rawmaterial','Partnumber','Thickness','Count','Weight','IDatetime',
                   'FZ1','FZ2','FZ3','FZ4','XM1','XM2','XM3','XM4'])
cur.execute("SELECT * FROM Out")
outstock = pd.DataFrame(cur.fetchall(),columns = ['ID','Barcode','Rawmaterial','Partnumber','Thickness','Count','Weight','ODatetime',
                   'FZ1','FZ2','FZ3','FZ4','XM1','XM2','XM3','XM4'])
conn.commit()
cur.close()
conn.close()
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Python读取Microsoft Access Database 的相关文章

随机推荐

  • 高通cDSP介绍汇总

    Qualcomm Hexagon Compute DSP cDSP 是高通平台上专门用来做通用计算的硬件加速单元 xff0c 与主机 CPU 相比 xff0c DSP 通常以较低的时钟速度运行 xff0c 并提供更多的并行指令级 这使得 D
  • PCB拼板方式

    Pcb拼板方式一般有三种 xff1a V割 V CUT 邮票孔以和空心连接条 PCB拼板方式 V割 V割 xff0c 又称V CUT xff0c 在规则板中使用较多 V割是在两个板子的连接处画一个槽 xff0c 只要将两个板子拼在一起 xf
  • 车联网名词缩写含义

    TSP xff1a Telematics Service Provider xff1b DSRC xff1a 专用短程通信技术是一种新型的技术 xff0c Dedicated Short RangeCommunication DSRC xf
  • 质量管理PPAP说明

    PPAP是英文Production Part Approval Process的缩写 xff0c 中文翻译为生产件批准程序 PPAP是TS16949质量管理体系五大工具之一 xff0c 用于汽车整车或零部件生产过程的质量管控 各种质量管理类
  • Vlookup最经典的10种用法

    该函数的语法规则如下 xff1a VLOOKUP lookup value table array col index num range lookup 参数 简单说明 输入数据类型 lookup value 要查找的值 数值 引用或文本字
  • 宝马项目化流程标准(BMW ABC flyer requirement)

    ABC flyer BMWQMT build phase requirement 宝马的项目流程标准叫做ABC flyer 也叫QMT build phase requirement 为什么叫这么名字 xff0c 是因为宝马项目的产品零件分
  • 数字无线广播(DAB、DRM)

    1 什么是数字广播 数字化技术指的是运用0和1两位数字编码 xff0c 通过电子计算机 光缆 通信卫星等设备 xff0c 来表达 传输和处理所有信息的技术 数字化技术一般包括 数字编码 数字压缩 数字传输 数字调制 与解调 等技术 所谓的数
  • 什么是IPD管理体系?

    集成产品开发 xff08 Integrated Product Development 简称IPD xff09 是一套产品开发的模式 理念与方法 源于美国PRTM公司出版的 产品及生命周期优化法 一书 最具有代表实践者有IBM和华为 IPD
  • 全球整车开发流程(GVDP)

    整车开发流程用于整车开发的管理控制 xff0c 其中换代开发 换型开发 年度改型开发和变型开发可以根据所开发产品的特点或资源环境需求 产品开发流程图 产品开发参考周期 如下 xff1a 1 平台项目 开发全新的车型平台 xff0c 采用全新
  • DataFrame 切片取值

    基本格式 xff1a dataframe 列名 1 取多列 列名要用中括号括起来 xff0c 所以下述命令 dataframe P4 profit rate P3PS P3NS 没问题 返回pandas core frame DataFra
  • APQP(advanced product quality planning先期产品质量策划)

    APQP xff08 advanced product quality planning先期产品质量策划 xff09 xff0c 圈子里面无论是做研发 做项目还是做SQE的都不陌生 xff0c 很多时候 xff0c 尤其是SQE会比较困惑
  • 8D和A3报告

    8D和3A报告 xff0c 他们都不仅仅是记录问题的一种文书 xff0c 而是解决问题的工具 A3发展于TPS xff08 Toyota Production system xff09 xff0c 可以用来解决问题 xff0c 沟通 xff
  • Ubuntu出现包依赖错误的解决方法

    大家在使用apt get安装软件时经常会出现这种包依赖错误 这主要是因为apt get的源中没有所要安装的package的依赖包 主要有以下两种解决方案 xff1a xff11 将CD加入Ubuntu的apt get源 参见我的另一篇博客
  • stm32 类型转换

    stm32怎么把uint8 t类型转换成int类型 可以使用强制类型转换 xff1a int n 61 int uint8 t 参考例子 xff1a include lt stdio h gt int main void uint8 t a
  • C语言不带头结点链表创建,删除,插入总结

    一 创建链表 1 第一种创建链表的方法 xff0c 注意对比和第二种创建链表的细微之处 xff0c typedef struct mynode int num float score struct mynode next Node Pnod
  • http协议基本认证 Authorization

    http协议是无状态的 xff0c 浏览器和web服务器之间可以通过cookie来身份识别 桌面应用程序 比如新浪桌面客户端 xff0c skydrive客户端 跟Web服务器之间是如何身份识别呢 xff1f 阅读目录 什么是HTTP基本认
  • Java 中大小端 int 与 byte 数组转换

    1 小端模式转换 1 1 int 转 byte 数组 xff0c 低位在前 xff0c 高位在后 将int数值转换为占四个字节的byte数组 xff0c 本方法适用于 低位在前 xff0c 高位在后 的顺序 和bytesToInt xff0
  • 无人机/FPV穿越机航模的遥控器/接收机等配件厂商

    本人最近迷恋上了穿越机 整理一些资料 xff0c 方便后来人学习 有其他更新资料 xff0c 欢迎留言 xff0c 争取打造成好的工具书 新手入门可以看百科 xff1a http wiki fpvbang com 穿越机电子系统表 xff1
  • FPV穿越机一启动就加速翻滚(死亡翻滚)解决办法

    最近不是开始入坑穿越机吗 xff0c 买了一个moblite7玩玩 xff0c 碰到了这个问题 大家在购买其他穿越机 xff0c 或者自组穿越机 xff0c 还有重置了穿越机的设置好 也很有可能碰到问题 xff0c 我把自己搜索并解决这个问
  • Python读取Microsoft Access Database

    公司有一个小零件进出库管理系统 xff0c 数据库是使用Microsoft Access Database xff0c 因长期存储会有生锈问题 xff0c 导致零件报废 因此基于原数据的进库出库在库数据 xff0c 做一个python脚本