python实现access2mysql &定时任务执行

 1.方案流程说明

python 盒子(在windows,即access库所在环境部署执行): python脚本实现access2mysql , 使用定时任务去执行

2.access配置说明:

  1. 安装access , 注意这里安装包必须新下载,无法直接使用其他包。 下载地址:https://www.microsoft.com/zh-cn/download/confirmation.aspx?id=13255

  2. access 驱动配置说明【注意开发环境windows10 , 64位】

 

 

3.python环境说明

3.1 找一个目录存有下面两个文件:py是脚本、config是配置文件,按照实际去配置即可!

3.2安装python 3.8环境

Python 3.8详细安装教程_million doors的博客-CSDN博客_python3.8安装教程

3.3 python环境参数配置

python环境变量配置(为了cmd能直接打开python)_若春、的博客-CSDN博客_python环境变量的配置

3.4 安装pyinstaller,如下图

3.5 安装函数库

# 安装函数库 否则执行会抛出:ModuleNotFoundError: No module named 'pyodbc'
pip install pymysql
pip install pyodbc

源码如下:

import pyodbc
import pymysql
#创建access数据库库连接
DBfile = r"D:/kisen/kisen-project/SynologyDrive/诸多项目===/普洱/tye.mdb"  # 数据库文件
conn_A = pyodbc.connect(r"DRIVER={Microsoft Access Driver (*.mdb, *.accdb)};DBQ=" + DBfile + ";Uid=;Pwd=88272008;charset=‘utf-8’;") # xingaolhw
cursor_A = conn_A.cursor()
#创建mysql数据库连接
conn_M = pymysql.connect(
    host='192.168.xxx.xx',
    user='root',
    passwd='xxxxx',#输入自己的mysql密码
    port=3306,
    db='accessdb',
    charset='utf8'
)
cursor_M = conn_M.cursor(pymysql.cursors.DictCursor)
#准备3个容器
tables = []
fields = []
field_str = []
#获取所有表名
for table_info in cursor_A.tables(tableType='TABLE'):
    tables.append(table_info.table_name)
#遍历所有表名
for table in tables:
    for row in cursor_A.columns(table):
        fields.append(row.column_name)
    # 判断下TABLE在MYSQL是否存在, 存在导入
    hasTable = cursor_M.execute(f"select * from information_schema.tables where table_name ='{table}'")
    if hasTable == 1:
        #进行sql语句拼接
        f = ','.join(fields)
        s = ','.join(['%s' for i in range(len(fields))])
        sql = f'insert into {table}({f}) values({s})'
        SQL = f"SELECT * from {table};"
        if table == 'SNKYGROne':
            sql = f'insert into {table}(`ZuHao`, `LingQI`, `PingZhong`, `OnekN`, `ShunXu`, `LenAv`, `WidAv`) values(%s,%s,%s,%s,%s,%s,%s)'
            SQL = f"SELECT `ZuHao`, `LingQI`, `PingZhong`, `OnekN`, `ShunXu`, `LenAv`, `WidAv` from {table};"
        print(sql)
        print(SQL)
        #获取到表的数据
        for row in cursor_A.execute(SQL):
            field_str.append(tuple(row))  # pyodbc.row -> tuple 否则sql提交失败
        count = cursor_M.executemany(sql, field_str)  # 传入多条数据
        print(f" table-'{table}' insert into mysql 数据量:" + str(count) + ", access数据量:" + str(len(field_str)))
        conn_M.commit()  # 提交更改

        fields.clear()
        field_str.clear()
    else:
        print(f" mysql do not exist table-'{table}'")

cursor_A.close()
conn_A.close()
cursor_M.close()  # 游标关闭
conn_M.close()
#单次手动执行python puer.py# 看到下图说明可以脚本执行成功啦!

4. windows 任务调度

Windows 任务调度程序定时执行Python脚本

 

时间设定每天固定一个时间即可。

重点下面这个设置:

程序或者脚本: C:\Users\michael\AppData\Local\Programs\Python\Python38\python.exe 【python安装下exe文件】

添加参数:D:\kisen\kisen-project\新建文件夹\puer\puer.py【执行文件位置\py】

起始于:D:\kisen\kisen-project\新建文件夹\puer【执行文件位置, 这里一定要配置,否则无法获取配置文件!!!】

测试一下:

右击任务运行一下,看下如下,会有py脚本执行的弹窗。查看一下数据库是否准确即可

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值