Pandas + Pyodbc 两种方式实现向MSSQL Table 中 Insert 数据

首先是Pandas.to_sql,优势就是简单粗暴。缺点是会重构数据表的结构和内容,默认主键变成index,从0开始.
下面是从Excel中读取数据插入table,

import sqlalchemy
import  pyodbc
import pandas as pd

path = r"C:\Users\shzbabao\Desktop\mrp.xlsx"
df = pd.read_excel(path)
data = df.iloc[1:, [0,1]]
data.columns = ['ColumnName','Value_Input']
engine = sqlalchemy.create_engine(   "mssql+pyodbc://用户名:密码@服务器/数据库?driver=SQL+Server+Native+Client+11.0")
data.to_sql('Checkinfo', con=engine, if_exists='replace')
#注意:table名前不能带dbo,否则会报错。如dbo.Checkinfo就是不可以的。

另一种实现方法不会改变数据表的结构,和我们日常在数据库中写的语句是一样的,缺点是比较考验数据库的语句能力。下面是示例:

import sqlalchemy
import  pyodbc
import pandas as pd


path =r'C:\Users\shzbabao\Desktop\outbount.xlsx'
df = pd.read_excel(path,sheet_name=0)
data = df.iloc[0:, [0, 1, 2, 3]]
data.columns = ['CarNumber', 'OrderNumber', 'PalletQty', 'CartonQty']
# data7.columns = ['ColumnName','Value_Input']

conn = pyodbc.connect(
    r'DRIVER={SQL Server Native Client 11.0};SERVER=服务器;DATABASE=数据库名;UID=用户名;PWD=密码')
cursor = conn.cursor()
for i in range(len(data)):
    CarNumber = str(data['CarNumber'].iloc[i])
    OrderNumber = str(data['OrderNumber'].iloc[i])
    PalletQty = str(data['PalletQty'].iloc[i])
    CartonQty = str(data['CartonQty'].iloc[i])
    sql='insert into JabraOutbounddata([CarNumber],[OrderNumber], [PalletQty],[CartonQty]) values(?,?,?,?)'
    cursor.execute(sql,(CarNumber,OrderNumber,PalletQty,CartonQty))
    # sql ="insert into JabraOutbounddata (CarNumber,OrderNumber,PalletQty,CartonQty) values(%s,%s,%s,%s)" %(CarNumber,OrderNumber,PalletQty,CartonQty)
    # cursor.execute(sql)
# row =cursor.fetchall()
print(data)
cursor.commit()#不能忽略,否则不会提交到数据库
cursor.close()
conn.close()

上面的两种方式都可以读取Excel数据insert 到db table。如果对数据的字段不作要求,而且后期不确定会不会增加字段的建议选择第一种。第二种针对生产环境,里面数据很多,而且要求不能更改字段。

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值