1.方案流程说明
python 盒子(在windows,即access库所在环境部署执行): python脚本实现access2mysql , 使用定时任务去执行
2.access配置说明:
-
安装access , 注意这里安装包必须新下载,无法直接使用其他包。 下载地址:https://www.microsoft.com/zh-cn/download/confirmation.aspx?id=13255
-
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 任务调度
时间设定每天固定一个时间即可。
重点下面这个设置:
程序或者脚本: 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脚本执行的弹窗。查看一下数据库是否准确即可