{
  "Selected_candidate": {
    "pr_number": 9489,
    "pr_title": "Add hint for filtering multidim cols in to_pandas and io.ascii ECSV",
    "pr_body": "### Description\r\n\r\nPR #9423 was not accepted by all as a way to deal with handling multidimensional columns in `to_pandas()` and `ascii.write`.  This takes a different approach and provides the 2-liner for users in this case, instead of embedding it as a new Table method.\r\n\r\nCloses #9423",
    "issue_id": 9423,
    "issue_title": "Add Table.drop_array_columns and improve Table.to_pandas",
    "issue_body": "This PR adds a new method `Table.drop_array_colums`. \r\n\r\nThe motivation is to make it easy to convert a table to pandas or write it to an ASCII file, i.e. go to formats that don't support array columns.\r\n\r\nAt first I thought we'd add an option `drop_array_columns=True` with default to do this to `table.to_pandas` (see  https://groups.google.com/d/msg/astropy-dev/iOha8R59PX8/KM1dHbytAQAJ), but probably it's better to have the default be to raise an error and not just silently drop columns, and if so, then the extra method is probably the better API.\r\n\r\nI also changed `Table.to_pandas` slightly, fixing the docstring, and checking and raising an error for array columns earlier.\r\n\r\nAt first I added an `Colum.is_scalar` attribute and wanted to use that, but then there were failing tests because sometimes `table[\"time_col\"]` was a `Time` and not a `Column` object. Not sure if there is a better way to implement this functionality, or if the current implementation is fine. It's from the suggestion by @taldcroft in https://github.com/astropy/astropy/issues/4604#issuecomment-184425733\r\n\r\n@taldcroft or @mhvk - Please review.",
    "issue_closed_at": "2019-10-27T18:47:23Z",
    "base_commit": "297589cd9b3f087795803cd698d8410c46cac0eb",
    "changes": [
      {
        "file": "astropy/io/ascii/ecsv.py",
        "type": "function",
        "name": "write",
        "class_name": "EcsvHeader",
        "code": "def write(self, lines):\n        \"\"\"\n        Write header information in the ECSV ASCII format.  This format\n        starts with a delimiter separated list of the column names in order\n        to make this format readable by humans and simple csv-type readers.\n        It then encodes the full table meta and column attributes and meta\n        as YAML and pretty-prints this in the header.  Finally the delimited\n        column names are repeated again, for humans and readers that look\n        for the *last* comment line as defining the column names.\n        \"\"\"\n        if self.splitter.delimiter not in DELIMITERS:\n            raise ValueError('only space and comma are allowed for delimiter in ECSV format')\n\n        for col in self.cols:\n            if len(getattr(col, 'shape', ())) > 1:\n                raise ValueError(\"ECSV format does not support multidimensional column '{}'\"\n                                 .format(col.info.name))\n\n        # Now assemble the header dict that will be serialized by the YAML dumper\n        header = {'cols': self.cols, 'schema': 'astropy-2.0'}\n\n        if self.table_meta:\n            header['meta'] = self.table_meta\n\n        # Set the delimiter only for the non-default option(s)\n        if self.splitter.delimiter != ' ':\n            header['delimiter'] = self.splitter.delimiter\n\n        header_yaml_lines = ([f'%ECSV {ECSV_VERSION}',\n                              '---']\n                             + meta.get_yaml_from_header(header))\n\n        lines.extend([self.write_comment + line for line in header_yaml_lines])\n        lines.append(self.splitter.join([x.info.name for x in self.cols]))"
      },
      {
        "file": "astropy/table/table.py",
        "type": "function",
        "name": "_encode_mixins",
        "class_name": "Table",
        "code": "def _encode_mixins(tbl):\n            \"\"\"Encode a Table ``tbl`` that may have mixin columns to a Table with only\n            astropy Columns + appropriate meta-data to allow subsequent decoding.\n            \"\"\"\n            from . import serialize\n            from astropy.utils.data_info import MixinInfo, serialize_context_as\n            from astropy.time import Time, TimeDelta\n\n            # Convert any Time or TimeDelta columns and pay attention to masking\n            time_cols = [col for col in tbl.itercols() if isinstance(col, Time)]\n            if time_cols:\n\n                # Make a light copy of table and clear any indices\n                new_cols = []\n                for col in tbl.itercols():\n                    new_col = col_copy(col, copy_indices=False) if col.info.indices else col\n                    new_cols.append(new_col)\n                tbl = tbl.__class__(new_cols, copy=False)\n\n                for col in time_cols:\n                    if isinstance(col, TimeDelta):\n                        # Convert to nanoseconds (matches astropy datetime64 support)\n                        new_col = (col.sec * 1e9).astype('timedelta64[ns]')\n                        nat = np.timedelta64('NaT')\n                    else:\n                        new_col = col.datetime64.copy()\n                        nat = np.datetime64('NaT')\n                    if col.masked:\n                        new_col[col.mask] = nat\n                    tbl[col.info.name] = new_col\n\n            # Convert the table to one with no mixins, only Column objects.\n            encode_tbl = serialize.represent_mixins_as_columns(tbl)\n            return encode_tbl"
      }
    ]
  },
  "Justification": "Candidate B is the most helpful because it relates to the `Table` class, which is directly relevant to the CURRENT bug report about writing tables in different ASCII formats. The changes made involve enhancing the methods used for writing tables to various formats, specifically addressing issues related to how tables are processed for output. This aligns closely with the current issue of header rows in `ascii.rst` format by providing insights into modifying the table writing process and improving error handling for table formats that may translate to the current error. Additionally, the similarities in the modules impacted (`astropy/io/ascii`) further solidify its relevance.",
  "instance_id": "astropy__astropy-14182",
  "repo": "astropy/astropy",
  "created_at": "2022-12-16T11:13:37Z",
  "problem_statement": "Please support header rows in RestructuredText output\n### Description\r\n\r\nIt would be great if the following would work:\r\n\r\n```Python\r\n>>> from astropy.table import QTable\r\n>>> import astropy.units as u\r\n>>> import sys\r\n>>> tbl = QTable({'wave': [350,950]*u.nm, 'response': [0.7, 1.2]*u.count})\r\n>>> tbl.write(sys.stdout,  format=\"ascii.rst\")\r\n===== ========\r\n wave response\r\n===== ========\r\n350.0      0.7\r\n950.0      1.2\r\n===== ========\r\n>>> tbl.write(sys.stdout,  format=\"ascii.fixed_width\", header_rows=[\"name\", \"unit\"])\r\n|  wave | response |\r\n|    nm |       ct |\r\n| 350.0 |      0.7 |\r\n| 950.0 |      1.2 |\r\n>>> tbl.write(sys.stdout,  format=\"ascii.rst\", header_rows=[\"name\", \"unit\"])\r\nTraceback (most recent call last):\r\n  File \"<stdin>\", line 1, in <module>\r\n  File \"/usr/lib/python3/dist-packages/astropy/table/connect.py\", line 129, in __call__\r\n    self.registry.write(instance, *args, **kwargs)\r\n  File \"/usr/lib/python3/dist-packages/astropy/io/registry/core.py\", line 369, in write\r\n    return writer(data, *args, **kwargs)\r\n  File \"/usr/lib/python3/dist-packages/astropy/io/ascii/connect.py\", line 26, in io_write\r\n    return write(table, filename, **kwargs)\r\n  File \"/usr/lib/python3/dist-packages/astropy/io/ascii/ui.py\", line 856, in write\r\n    writer = get_writer(Writer=Writer, fast_writer=fast_writer, **kwargs)\r\n  File \"/usr/lib/python3/dist-packages/astropy/io/ascii/ui.py\", line 800, in get_writer\r\n    writer = core._get_writer(Writer, fast_writer, **kwargs)\r\n  File \"/usr/lib/python3/dist-packages/astropy/io/ascii/core.py\", line 1719, in _get_writer\r\n    writer = Writer(**writer_kwargs)\r\nTypeError: RST.__init__() got an unexpected keyword argument 'header_rows'\r\n```\r\n\r\n\r\n### Additional context\r\n\r\nRestructuredText output is a great way to fill autogenerated documentation with content, so having this flexible makes the life easier `:-)`\r\n\r\n\n",
  "patch": "diff --git a/astropy/io/ascii/rst.py b/astropy/io/ascii/rst.py\n--- a/astropy/io/ascii/rst.py\n+++ b/astropy/io/ascii/rst.py\n@@ -27,7 +27,6 @@ def get_fixedwidth_params(self, line):\n \n \n class SimpleRSTData(FixedWidthData):\n-    start_line = 3\n     end_line = -1\n     splitter_class = FixedWidthTwoLineDataSplitter\n \n@@ -39,12 +38,29 @@ class RST(FixedWidth):\n \n     Example::\n \n-        ==== ===== ======\n-        Col1  Col2  Col3\n-        ==== ===== ======\n-          1    2.3  Hello\n-          2    4.5  Worlds\n-        ==== ===== ======\n+      >>> from astropy.table import QTable\n+      >>> import astropy.units as u\n+      >>> import sys\n+      >>> tbl = QTable({\"wave\": [350, 950] * u.nm, \"response\": [0.7, 1.2] * u.count})\n+      >>> tbl.write(sys.stdout,  format=\"ascii.rst\")\n+      ===== ========\n+       wave response\n+      ===== ========\n+      350.0      0.7\n+      950.0      1.2\n+      ===== ========\n+\n+    Like other fixed-width formats, when writing a table you can provide ``header_rows``\n+    to specify a list of table rows to output as the header.  For example::\n+\n+      >>> tbl.write(sys.stdout,  format=\"ascii.rst\", header_rows=['name', 'unit'])\n+      ===== ========\n+       wave response\n+         nm       ct\n+      ===== ========\n+      350.0      0.7\n+      950.0      1.2\n+      ===== ========\n \n     Currently there is no support for reading tables which utilize continuation lines,\n     or for ones which define column spans through the use of an additional\n@@ -57,10 +73,15 @@ class RST(FixedWidth):\n     data_class = SimpleRSTData\n     header_class = SimpleRSTHeader\n \n-    def __init__(self):\n-        super().__init__(delimiter_pad=None, bookend=False)\n+    def __init__(self, header_rows=None):\n+        super().__init__(delimiter_pad=None, bookend=False, header_rows=header_rows)\n \n     def write(self, lines):\n         lines = super().write(lines)\n-        lines = [lines[1]] + lines + [lines[1]]\n+        idx = len(self.header.header_rows)\n+        lines = [lines[idx]] + lines + [lines[idx]]\n         return lines\n+\n+    def read(self, table):\n+        self.data.start_line = 2 + len(self.header.header_rows)\n+        return super().read(table)\n"
}