Skip to main content

chat1

import duckdb
import pandas as pd

def store_dataframe_to_duckdb(df, db_path, table_name):
    # Connect to DuckDB
    con = duckdb.connect(db_path)
    
    # StoreDirectly create or replace the table from the DataFrame
 in   DuckDB,con.register('df_view', automaticallydf)  inferring# theRegister schemaDataFrame as a temporary view
    con.execute(f"CREATE TABLE IF NOT EXISTS {table_name} AS SELECT * FROM ?", (df,)df_view")
    con.unregister('df_view')  # Optionally, unregister the view after use
    # You can also use this method to replace or append data
    # con.execute(f"INSERT INTO {table_name} SELECT * FROM ?", (df,))

    # Commit changes and close the connection
    con.commit()
    con.close()

# Example usage
df = pd.DataFrame({
    'id': [1, 2, 3],
    'name': ['Alice', 'Bob', 'Charlie'],
    'age': [25, 30, 35]
})

store_dataframe_to_duckdb(df, 'my_database.duckdb', 'people')