使用 index_col 时 Pandas read_sql 列不起作用 - 而是返回所有列

Hen*_*huy 7 python postgresql pandas

我正在使用pandas.read_sql()命令从我的 postgresql 数据库中获取数据。SQL 查询通常使用许多列创建,我只想使用一列作为索引从中获取特定列。创建这样的示例表test_table

column1 column2 column3
1       2       3
2       4       6
3       6       9
Run Code Online (Sandbox Code Playgroud)

我尝试使用index_colandcolumns参数 frompandas.read_sql()来获取column1索引和column2数据(并忽略column3!)。但它总是返回整个表。也当写columns=['column1', 'column2']什么都没有改变......

我正在使用 python 2.7.6 和 pandas 0.17.1 - 感谢您的帮助!

示例代码:

import pandas
import psycopg2
import sqlalchemy


def connect():
    connString = (
        "dbname=test_db "
        "host=localhost "
        "port=5432 "
        "user=postgres "
        "password=password"
    )
    return psycopg2.connect(connString)

engine = sqlalchemy.create_engine(
            'postgresql://',
            creator=connect)
sql = (
    'SELECT '
    'column1, '
    'column2, '
    'column3 '
    'FROM test_table'
)
data = pandas.read_sql(
    sql,
    engine,
    index_col=['column1'],
    columns=['column2'])
print(data)
Run Code Online (Sandbox Code Playgroud)

小智 7

我认为该参数columns对您不起作用,因为您使用的是 sql 语句而不是为它提供表名。

如熊猫网站所述:

列:列表,默认值:无 要从 sql 表中选择的列名列表(仅在读取表时使用)。

因此,我认为如果您尝试:

pandas.read_sql('test_table', engine, index_col=['column1'], columns=['column2'])
Run Code Online (Sandbox Code Playgroud)

columns 论点实际上会起作用。

  • 可惜对sql语句不起作用 (3认同)