fix(extract,transform): fix COT/prices column name mismatches + OWM rate limit skip
- fct_cot_positioning: quote Swap__Positions_Short_All and Swap__Positions_Spread_All (CSV uses double underscore; DuckDB preserves header names exactly) - fct_cot_positioning: quote Report_Date_as_YYYY-MM-DD (dashes preserved in header) - fct_coffee_prices: quote "Adj Close" (space in CSV header) - openmeteo/execute.py: skip API call in backfill when all daily files already exist (_count_existing_files pre-check prevents 429 rate limit on re-runs) - dev_run.sh: open browser as admin@beanflows.coffee instead of pro@ Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
@@ -24,7 +24,7 @@ WITH src AS (
|
||||
), cast_and_clean AS (
|
||||
SELECT
|
||||
TRIM(market_and_exchange_names) AS market_and_exchange_name, /* Identifiers */
|
||||
report_date_as_yyyy_mm_dd::DATE AS report_date,
|
||||
"Report_Date_as_YYYY-MM-DD"::DATE AS report_date,
|
||||
TRIM(cftc_commodity_code) AS cftc_commodity_code,
|
||||
TRIM(cftc_contract_market_code) AS cftc_contract_market_code,
|
||||
TRIM(contract_units) AS contract_units,
|
||||
@@ -32,8 +32,8 @@ WITH src AS (
|
||||
TRY_CAST(prod_merc_positions_long_all AS INT) AS prod_merc_long, /* Producer / Merchant (commercial hedgers: exporters, processors) */
|
||||
TRY_CAST(prod_merc_positions_short_all AS INT) AS prod_merc_short,
|
||||
TRY_CAST(swap_positions_long_all AS INT) AS swap_long, /* Swap dealers */
|
||||
TRY_CAST(swap_positions_short_all AS INT) AS swap_short,
|
||||
TRY_CAST(swap_positions_spread_all AS INT) AS swap_spread,
|
||||
TRY_CAST("Swap__Positions_Short_All" AS INT) AS swap_short,
|
||||
TRY_CAST("Swap__Positions_Spread_All" AS INT) AS swap_spread,
|
||||
TRY_CAST(m_money_positions_long_all AS INT) AS managed_money_long, /* Managed money (hedge funds, CTAs — the primary speculative signal) */
|
||||
TRY_CAST(m_money_positions_short_all AS INT) AS managed_money_short,
|
||||
TRY_CAST(m_money_positions_spread_all AS INT) AS managed_money_spread,
|
||||
@@ -44,7 +44,7 @@ WITH src AS (
|
||||
TRY_CAST(nonrept_positions_short_all AS INT) AS nonreportable_short,
|
||||
TRY_CAST(prod_merc_positions_long_all AS INT) /* Net positions (long minus short per category) */ - TRY_CAST(prod_merc_positions_short_all AS INT) AS prod_merc_net,
|
||||
TRY_CAST(m_money_positions_long_all AS INT) - TRY_CAST(m_money_positions_short_all AS INT) AS managed_money_net,
|
||||
TRY_CAST(swap_positions_long_all AS INT) - TRY_CAST(swap_positions_short_all AS INT) AS swap_net,
|
||||
TRY_CAST(swap_positions_long_all AS INT) - TRY_CAST("Swap__Positions_Short_All" AS INT) AS swap_net,
|
||||
TRY_CAST(other_rept_positions_long_all AS INT) - TRY_CAST(other_rept_positions_short_all AS INT) AS other_reportable_net,
|
||||
TRY_CAST(nonrept_positions_long_all AS INT) - TRY_CAST(nonrept_positions_short_all AS INT) AS nonreportable_net,
|
||||
TRY_CAST(change_in_open_interest_all AS INT) AS change_open_interest, /* Week-over-week changes */
|
||||
@@ -64,7 +64,7 @@ WITH src AS (
|
||||
MAKE_DATE(STR_SPLIT(filename, '/')[-2]::INT, 1, 1) AS ingest_date, /* Ingest date: derived from landing path year directory */ /* Path: .../cot/{year}/{etag}.csv.gzip → extract year from [-2] */
|
||||
HASH(
|
||||
cftc_commodity_code,
|
||||
report_date_as_yyyy_mm_dd,
|
||||
"Report_Date_as_YYYY-MM-DD",
|
||||
cftc_contract_market_code,
|
||||
open_interest_all,
|
||||
m_money_positions_long_all,
|
||||
@@ -77,7 +77,7 @@ WITH src AS (
|
||||
WHERE
|
||||
NOT TRIM(cftc_commodity_code) IS NULL
|
||||
AND LENGTH(TRIM(cftc_commodity_code)) > 0
|
||||
AND NOT report_date_as_yyyy_mm_dd::DATE IS NULL
|
||||
AND NOT "Report_Date_as_YYYY-MM-DD"::DATE IS NULL
|
||||
), deduplicated AS (
|
||||
SELECT
|
||||
ANY_VALUE(market_and_exchange_name) AS market_and_exchange_name,
|
||||
|
||||
Reference in New Issue
Block a user