汉字插入Isu

2024-04-29 10:23:21 发布

您现在位置:Python中文网/ 问答频道 /正文

我有以下熊猫数据帧

enter image description here

需要用汉字将所有值插入到数据仓库中,但汉字被指示为垃圾(????)(百å¨è‹±åšï¼ˆèˆŸå±±ï¼‰å•¤é…’有é™å…¬å¸ )就像上面的一样 插入查询是动态准备的。 我需要帮助处理以下情况:

以UTF-8格式读取文件,并使用pyodbc连接和字符集UTF-8写入数据仓库。你知道吗

df=pd.read_csv(filename,dtype='str',encoding='UTF-8')
cnxn = database_connect() ##Connect to database##
cnxn.setencoding(ctype=pyodbc.SQL_CHAR, encoding='UTF-8')
cnxn.autocommit = True
cursor = cnxn.cursor()
for y in range(len(df)):
 inst='insert into '+tablename+' values ('
 for x in range(len(clm)):
  if str(df.iloc[y,x])=='nan':
   df.iloc[y,x]=''
  if x!=len(clm)-1:
   inst_val=inst_val+"'"+str(df.iloc[y,x]).strip().replace("'",'')+"'"+","
  else:
   inst_val=inst_val+"'"+str(df.iloc[y,x]).strip().replace("'",'')+"'"+")"
 inst=inst+inst_val #########prepare insert statment from values inside in-memory data###########
 inst_val=''
 print("Inserting value into table")
 try:
  cursor.execute(inst) ##########Execute insert statement##############
  print("1 row inserted")
 except Exception as e:
  print (inst)
  print (e)

应将相同的like值插入sql数据仓库


Tags: indflenvalcursorutfencoding数据仓库
1条回答
网友
1楼 · 发布于 2024-04-29 10:23:21

您正在使用动态SQL来构造包含汉字的字符串文本,但您正在将它们创建为

insert into tablename values ('你好')

当SQL Server要求Unicode字符串文字的格式为

insert into tablename values (N'你好')

最好使用适当的参数化查询来避免此类问题:

sql = "insert into tablename values (?)"
params = ('你好',)
cursor.execute(sql, params)

相关问题 更多 >