- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我搜索了很多例子,但没有一个能够解决我的具体问题。感谢您抽出时间,因为我一生都无法找到解决此问题的方法。我正在尝试使用 Python 中的 for 循环将 CSV 文件插入到 Azure SQL Server 数据库中。我已经多次使用同一个 python 程序来处理多个不同的 CSV 文件,所以我知道根本问题在于当前的 CSV。下面是我的 Python 代码的简短片段以及错误。如何对 CSV 进行编码,以便不再发生此错误(如前所述,我已经尝试了多个类似线程的解决方案,但无法解决此问题)。
代码:
csvfile = open('C:\\file.csv', 'r')
csv_data = csv.reader(csvfile)
SQL = """Insert into Idea_Pipeline( [col_1], [col_2], [col_3], [col_4])
values (?,?,?,?)
for row in csv_data:
first_row = next(csv_data)
cursor2.execute(SQL, row)
如上所述,这只是我的代码片段,但是我已经使用过多次,所以我知道语法是正确的。以下是我无法解决的错误。
错误:
Traceback (most recent call last):
File "Idea_Pipeline.py", line 46, in <module>
cursor2.execute(SQL, row)
UnicodeDecodeError: 'ascii' codec can't decode byte 0x96 in position 114:
ordinal not in range(128)
再次非常感谢您的帮助。
此外 - 我已尝试将此 CSV 批量插入本地 SQL Server 数据库,但收到错误“操作系统错误代码(空)”
再次感谢您的任何帮助或建议,因为我还是个新手,并且正在尝试尽可能多地学习。
最佳答案
听起来这是您的 CSV 文件第一次包含“ascii”编解码器无法处理的字符。 0x96
不是 latin1
字符集中的字符之一,因此下一个最可能的候选字符可能是 windows-1252
,其中 0x96
代表“En Dash”字符 (U+2013)。如果是这样的话
# -*- coding: windows-1252 -*-
import csv
import pyodbc
import sys
print("Python version " + sys.version)
print("pyodbc version " + pyodbc.version)
cnxn = pyodbc.connect("DSN=myDb", autocommit=True)
crsr = cnxn.cursor()
crsr.execute("CREATE TABLE #foo (id INT PRIMARY KEY, txtcol VARCHAR(50))")
with open(r'C:\Users\gord\Desktop\sample.csv', 'rb') as csvfile:
csv_data = csv.reader(csvfile)
sql = "Insert into #foo ([id], [txtcol]) VALUES (?,?)"
print("")
print("Rows retrieved from CSV file:")
for row in csv_data:
print(row)
crsr.execute(sql, [cell.decode('windows-1252') for cell in row])
print("")
print("Values retrieved from table:")
for row in crsr.execute("SELECT * FROM #foo").fetchall():
print(row)
cnxn.close()
将产生以下输出
Python version 2.7.13 (v2.7.13:a06454b1afa1, Dec 17 2016, 20:42:59) [MSC v.1500 32 bit (Intel)]
pyodbc version 4.0.16
Rows retrieved from CSV file:
['1', 'foo']
['2', 'test\x96data']
Values retrieved from table:
(1, u'foo')
(2, u'test\u2013data')
关于python - “ascii”编解码器无法解码 - 通过 pyodbc 将 CSV 转换为 SQL Server,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44165079/
如果你有一个简单的程序名 pyodbcTest.py import pyodbc print "pass" 然后使用 cx_freeze 编译它 cxfreeze --targe-dir=cxTest
我有一个 FileMaker db 在 Mac Mini 上的 FileMaker Server 14 上运行,我正在尝试使用 pyodbc 来获取它。进展不顺利。 首先,什么有效: telnet 1
这里有点菜鸟。我正在尝试创建一个 python 脚本来对基于 SQL 的数据库进行压力测试。 我一直在尝试使用 pyodbc 连接到数据库,但是我在 pyodbc.connect(connection
我想使用 pyodbc 和 freetds 从 Python 连接到 SQL SERVER 数据库。 我的连接正常。 我的代码: class GetSystems(Resource): def get
我正在尝试将 pyodbc 库导入 google colab,但出现此错误。 以防万一,我在我的笔记本中安装了 Anaconda,而且我从来没有遇到过 pyodbc 的问题。 你能帮我吗? 太棒了!
我最近跑了pip install pyodbc 。这表明它在cmd上成功安装了pyodbc。 但是当我这样做时 import pyodbc在 IDLE 中,我收到一条错误消息“没有名为 pyodbc
我写了一个简短的 python 脚本,它试图导入 pyodbc 扩展包,以便我可以访问我的 SQL 表。 import pyodbc as pyodbc cnxn = pyodbc.connect('
我正在尝试使用列表作为值的源将数据插入到 Access mdb 文件中。 cursor.execute("select * from Components") cursor.executemany("
我使用 pyodbc 的时间很短,现在面临着从文件中应用 sql 脚本来执行一些 View 创建的问题。为了应用 sql 文件,我使用另一个线程中的示例 - Follow up: Execute .s
我传递给 pyodbc.connect(conn_str) 的 conn_str 是: conn_str = str("DRIVER={{ODBC Driver 13 for SQL Server}}
好的,我已经在 mac 上安装了 python3.8,分别安装了多个 odbcdrivers。 我创建了一个新的虚拟环境,并在该环境中运行: >>> import pyodbc >>> pyodbc.
我有一个在Mac Mini上的FileMaker Server 14上运行的FileMaker db,我试图通过pyodbc来解决。不好 首先,什么有效: telnet 192.169.19.3 23
我可以按照以下说明确定是否安装了 suds: checking suds version in python 即通过在 Python 控制台中运行以下命令: >>>> import suds >>>>
我可以按照以下说明确定是否安装了 suds: checking suds version in python 即通过在 Python 控制台中运行以下命令: >>>> import suds >>>>
当我使用 pyodbc 查询 SQL 服务器时,我只得到我请求的字段的名称(而不是值本身)。 import pyodbc conn = pyodbc.connect(connection_string
我尝试使用以下代码查询 SQL Server 2012 数据库: import pyodbc class sqlserverConnector: def __init__(self, conn
我目前正在编写一个程序,该程序将从 Excel 电子表格中获取数据并将其插入到我在程序中创建的 SQL Server 表中。 我之前已将日期时间列指定为 nvarchar(250) ,以便使整个程序正
如果有人能指出我正确的方向,我会很感兴趣。 我有一个很长的存储过程(其中还包含对其中其他存储过程的调用),用于更新各种表。 如果我在管理工作室中运行存储过程,它运行良好。如果我从 pyodbc 调用它
你好,我有一个带有 SQL 的 Python 脚本,我使用 fecthall() 方法提取我想要的元素,直到那里一切都很好,因为我想将两列(datetime.date 和 datetime.time)
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是偏离主题的,
我是一名优秀的程序员,十分优秀!