热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

python–SQLServerDATE作为字符串检索到pandas中

当我从SQLServer将“Date”变量拉入Python/Pandas时,它将作为“对象”出现.我已经安装并尝试了几个驱动程序(代码中显示的注释驱动程序),每次都有相同的结果:

当我从SQL Server将“Date”变量拉入Python / Pandas时,它将作为“对象”出现.我已经安装并尝试了几个驱动程序(代码中显示的注释驱动程序),每次都有相同的结果:

import pandas as pd
import pyodbc
conn_str = (
r'Driver={SQL Server Native Client 11.0};'
# r'Driver={SQL Server Native Client 10.0};'
# r'Driver={ODBC Driver 11 for SQL Server};'
# r'Driver={ODBC Driver 13 for SQL Server};'
# r'Driver={SQL Server};'
r'Server=MyServer;'
r'Database=MyDB;'
r'Trusted_COnnection=yes;'
)
cnxn = pyodbc.connect(conn_str)
sql = (
"Select cast('2017-08-19' as date) [DateVar]"
", cast('2017-08-19' as datetime) [DateTimeVar]"
", cast('2017-08-19' as datetime2) [DateTime2Var]"
)
d2 = pd.read_sql(sql,cnxn)
cnxn.close()
print(d2.dtypes)

返回的结果是:

DateVar object
DateTimeVar datetime64[ns]
DateTime2Var datetime64[ns]
dtype: object

我希望DateVar成为日期时间.任何想法为什么会这样?

和这家伙一样的问题:
pyodbc returns SQL Server DATE fields as strings
但他的修复是使用我安装的{SQL Server Native Client 10.0}并且不适合我.

我正在连接的SQL Server版本是:

Microsoft SQL Server 2012 (SP3) (KB3072779) - 11.0.6020.0 (X64)
Oct 20 2015 15:36:27
Copyright (c) Microsoft Corporation
Enterprise Edition (64-bit) on Windows NT 6.1 (Build 7601: Service Pack 1)

更新

1 GT;

基于Max的输入,尝试了sqlalchemy,但没有运气,这仍然给了我一个字符串:

import sqlalchemy as sa
engine = sa.create_engine('mssql+pyodbc://MyDatabase/MyDB?driver=SQL+Server+Native+Client+10.0')
d2 = pd.read_sql(sql, engine)

2 – ;

基于Flipper的Q,只使用Pyodbc游标完成此操作,看起来使用Native Client 11.0时光标中返回了正确的日期数据类型:

(('DateVar', datetime.date, None, 10, 10, 0, True),
('DateTimeVar', datetime.datetime, None, 23, 23, 3, True),
('DateTime2Var', datetime.datetime, None, 27, 27, 7, True))

这表明在加载到数据帧时,问题在于Pandas处理dtype datetime.date.

解决方法:

使用pandas.read_sql的parse_dates参数指定在数据帧加载时将DateVar列值显式转换为datetime.

更新了原始代码段:

...
d2 = pd.read_sql(sql=sql, con=cnxn, # explicitly convert DATE type to datetime object parse_dates=["DateVar"])
cnxn.close()
print(d2.dtypes)

返回

DateVar datetime64[ns]
DateTimeVar datetime64[ns]
DateTime2Var datetime64[ns]
dtype: object

在Windows上使用pyodbc 4.0.17,pandas 0.20.3和SQL Server 2014进行了测试.


推荐阅读
  • 在使用 SQL Server 时,连接故障是用户最常见的问题之一。通常,连接 SQL Server 的方法有两种:一种是通过 SQL Server 自带的客户端工具,例如 SQL Server Management Studio;另一种是通过第三方应用程序或开发工具进行连接。本文将详细分析导致连接故障的常见原因,并提供相应的解决策略,帮助用户有效排除连接问题。 ... [详细]
  • JUC(三):深入解析AQS
    本文详细介绍了Java并发工具包中的核心类AQS(AbstractQueuedSynchronizer),包括其基本概念、数据结构、源码分析及核心方法的实现。 ... [详细]
  • 本文介绍了在 Java 编程中遇到的一个常见错误:对象无法转换为 long 类型,并提供了详细的解决方案。 ... [详细]
  • MySQL 5.7 学习指南:SQLyog 中的主键、列属性和数据类型
    本文介绍了 MySQL 5.7 中主键(Primary Key)和自增(Auto-Increment)的概念,以及如何在 SQLyog 中设置这些属性。同时,还探讨了数据类型的分类和选择,以及列属性的设置方法。 ... [详细]
  • 基于Net Core 3.0与Web API的前后端分离开发:Vue.js在前端的应用
    本文介绍了如何使用Net Core 3.0和Web API进行前后端分离开发,并重点探讨了Vue.js在前端的应用。后端采用MySQL数据库和EF Core框架进行数据操作,开发环境为Windows 10和Visual Studio 2019,MySQL服务器版本为8.0.16。文章详细描述了API项目的创建过程、启动步骤以及必要的插件安装,为开发者提供了一套完整的开发指南。 ... [详细]
  • 深入剖析Java中SimpleDateFormat在多线程环境下的潜在风险与解决方案
    深入剖析Java中SimpleDateFormat在多线程环境下的潜在风险与解决方案 ... [详细]
  • 本指南详细介绍了在Linux环境中高效连接MySQL数据库的方法。用户可以通过安装并使用`mysql`客户端工具来实现本地连接,具体命令为:`mysql -u 用户名 -p 密码 -h 主机`。例如,使用管理员账户连接本地MySQL服务器的命令为:`mysql -u root -p pass`。此外,还提供了多种配置优化建议,以确保连接过程更加稳定和高效。 ... [详细]
  • 利用 Spring BeanUtils 实现 JavaBean 的深度克隆与属性复制 ... [详细]
  • NX二次开发:UFUN点收集器UF_UI_select_point_collection详解
    本文介绍了如何在NX中使用UFUN库进行点收集器的二次开发,包括必要的头文件包含、初始化和选择点集合的具体实现。 ... [详细]
  • 解决Bootstrap DataTable Ajax请求重复问题
    在最近的一个项目中,我们使用了JQuery DataTable进行数据展示,虽然使用起来非常方便,但在测试过程中发现了一个问题:当查询条件改变时,有时查询结果的数据不正确。通过FireBug调试发现,点击搜索按钮时,会发送两次Ajax请求,一次是原条件的请求,一次是新条件的请求。 ... [详细]
  • POJ 2482 星空中的星星:利用线段树与扫描线算法解决
    在《POJ 2482 星空中的星星》问题中,通过运用线段树和扫描线算法,可以高效地解决星星在窗口内的计数问题。该方法不仅能够快速处理大规模数据,还能确保时间复杂度的最优性,适用于各种复杂的星空模拟场景。 ... [详细]
  • 本文深入解析了Java 8并发编程中的`AtomicInteger`类,详细探讨了其源码实现和应用场景。`AtomicInteger`通过硬件级别的原子操作,确保了整型变量在多线程环境下的安全性和高效性,避免了传统加锁方式带来的性能开销。文章不仅剖析了`AtomicInteger`的内部机制,还结合实际案例展示了其在并发编程中的优势和使用技巧。 ... [详细]
  • 在C#中开发MP3播放器时,我正在考虑如何高效存储元数据以便快速检索。选择合适的数据结构,如字典或数组,对于优化性能至关重要。字典能够提供快速的键值对查找,而数组则在连续存储和遍历方面表现优异。根据具体需求,合理选择数据结构将显著提升应用的响应速度和用户体验。 ... [详细]
  • 投融资周报 | Circle 达成 4 亿美元融资协议,唯一艺术平台 A 轮融资超千万美元 ... [详细]
  • 在MySQL中实现时间比较功能的详细解析与应用
    在MySQL中实现时间比较功能的详细解析与应用。本文深入探讨了MySQL中时间比较的实现方法,重点介绍了`UNIX_TIMESTAMP`函数的应用。该函数可以接收一个日期时间参数,也可以不带参数使用,其返回值为Unix时间戳,便于进行时间的精确比较和计算。此外,文章还涵盖了其他相关的时间处理函数和技巧,帮助读者更好地理解和掌握MySQL中的时间操作。 ... [详细]
author-avatar
大佬銘銘銘銘銘
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有