gpt4 book ai didi

python - 将 bytearray 从 VARBINARY(16) 列转换为 IP 地址

转载 作者:行者123 更新时间:2023-11-28 22:24:19 26 4
gpt4 key购买 nike

我需要从 HP Vertica 数据库中提取大量数据并将其保存到文件中。我将 Vertica 的官方 ODBC 驱动程序与 pyodbc 一起使用。

这是我到目前为止所做的:

cnxn = pyodbc.connect('DRIVER={Vertica};SERVER=localhost;DATABASE=db;UID=user;PWD=pw')
cnxn.setdecoding(pyodbc.SQL_CHAR, encoding='utf-8')
cnxn.setdecoding(pyodbc.SQL_WCHAR, encoding='utf-8')
cnxn.setencoding(str, encoding='utf-8')
cnxn.setencoding(unicode, encoding='utf-8')
cur = cnxn.cursor()
cur.execute("SELECT * FROM schema.table LIMIT 3")

然后读取数据

for row in cur:
print row

大多数字段都返回得很好 - unicode 文本、数字或日期时间。但是对于存储 IP 地址的字段,我得到以下信息:

bytearray(b'\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\xff\xff\no\x19\\')

如何将其转换为文本?

非常感谢任何帮助!

谢谢!

最佳答案

我看到有一个可接受的答案,但是...对于所有其他答案:

如果您的数据在 Vertica 中,非常要做的第一件事就是查看优秀的 SQL 引用手册。在这种情况下,您会发现一个内置函数,用于将表示为 VARBINARY 列的 IPv6 地址转换为字符串。

更简单,更快:

SELECT V6_NTOA(your_column_here) ;

关于python - 将 bytearray 从 VARBINARY(16) 列转换为 IP 地址,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46475449/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com