Fokko commented on code in PR #41: URL: https://github.com/apache/iceberg-python/pull/41#discussion_r1429891452
########## pyiceberg/io/pyarrow.py: ########## @@ -1565,13 +1564,54 @@ def fill_parquet_file_metadata( del upper_bounds[field_id] del null_value_counts[field_id] - df.file_format = FileFormat.PARQUET df.record_count = parquet_metadata.num_rows - df.file_size_in_bytes = file_size df.column_sizes = column_sizes df.value_counts = value_counts df.null_value_counts = null_value_counts df.nan_value_counts = nan_value_counts df.lower_bounds = lower_bounds df.upper_bounds = upper_bounds df.split_offsets = split_offsets + + +def write_file(table: Table, tasks: Iterator[WriteTask]) -> Iterator[DataFile]: + task = next(tasks) + + try: + _ = next(tasks) + # If there are more tasks, raise an exception + raise ValueError("Only unpartitioned writes are supported: https://github.com/apache/iceberg-python/issues/208") + except StopIteration: + pass + + df = task.df + + file_path = f'{table.location()}/data/{_generate_datafile_filename("parquet")}' + file_schema = schema_to_pyarrow(table.schema()) Review Comment: Thanks @jqin61 for testing this as it is paramount that the field-IDs are written properly. I'm able to reproduce this locally: ``` <pyarrow._parquet.ParquetSchema object at 0x138782440> required group field_id=-1 schema { optional double field_id=-1 lat; optional double field_id=-1 long; } ``` After changing this to `PARQUET:field_id` it is fixed indeed: ``` parq ~/Desktop/00000-0-f4a20311-0574-4d24-8b8e-2cdf747581af-0.parquet --schema # Schema <pyarrow._parquet.ParquetSchema object at 0x12087e340> required group field_id=-1 schema { optional double field_id=1 lat; optional double field_id=2 long; } ``` Thanks for flagging this! -- This is an automated message from the Apache Git Service. To respond to the message, please log on to GitHub and use the URL above to go to the specific comment. To unsubscribe, e-mail: issues-unsubscr...@iceberg.apache.org For queries about this service, please contact Infrastructure at: us...@infra.apache.org --------------------------------------------------------------------- To unsubscribe, e-mail: issues-unsubscr...@iceberg.apache.org For additional commands, e-mail: issues-h...@iceberg.apache.org