+-------------+---------+
|Column Name |Type|+-------------+---------+
| product_id | int || store1 | int || store2 | int || store3 | int |+-------------+---------+
product_id is the primary key (column with unique values) for this table.
Each row in this table indicates the product’s price in 3 different stores: store1, store2, and store3.
If the product is not available in a store, the price will be null in that store’s column.
Write a solution to rearrange the Products table so that each row has (product_id, store, price). If a product is not available in a store, do not include a row with that product_id and store combination in the result table.
Explanation:
Product 0 is available in all three stores with prices 95, 100, and 105 respectively.
Product 1 is available in store1 with price 70 and store3 with price 80. The product is not available in store2.
SELECT product_id, 'store1'AS store, store1 AS price FROM Products WHERE store1 ISNOTNULLUNIONSELECT product_id, 'store2'AS store, store2 AS price FROM Products WHERE store2 ISNOTNULLUNIONSELECT product_id, 'store3'AS store, store3 AS price FROM Products WHERE store3 ISNOTNULLORDERBY product_id, stor
import pandas as pd
defrearrange_products_table(products: pd.DataFrame) -> pd.DataFrame:
rearranged_rows = []
# Iterate over each row in the original tablefor _, row in products.iterrows():
product_id = row['product_id']
# Check each store for price availabilityfor store_col in ['store1', 'store2', 'store3']:
price = row[store_col]
if pd.notna(price):
# If the price is not null, add the (product_id, store, price) tuple to the list rearranged_rows.append((product_id, store_col, price))
# Create a new DataFrame with the rearranged rows result_df = pd.DataFrame(rearranged_rows, columns=['product_id', 'store', 'price'])
return result_df