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 论点实际上会起作用。