From be127bd66b891e4e87f332af2e5722ffecae7250 Mon Sep 17 00:00:00 2001 From: alifeee Date: Sun, 5 Nov 2023 01:43:52 +0000 Subject: [PATCH 1/3] remove use_index and references to it --- gspread/worksheet.py | 21 ++++----------------- 1 file changed, 4 insertions(+), 17 deletions(-) diff --git a/gspread/worksheet.py b/gspread/worksheet.py index 7abf37af9..58c81f0b4 100644 --- a/gspread/worksheet.py +++ b/gspread/worksheet.py @@ -571,7 +571,6 @@ def get_records( # noqa: C901 # this comment disables the complexity check for self, empty2zero=False, head=1, - use_index=0, first_index=None, last_index=None, default_blank="", @@ -588,17 +587,15 @@ def get_records( # noqa: C901 # this comment disables the complexity check for Cell values are numericised (strings that can be read as ints or floats are converted), unless specified in numericise_ignore - Can be used to read data from rows (use_index=0) or columns (use_index=1) (default is 0), + Can be used to read data from rows, check the examples below for more details. :param bool empty2zero: (optional) Determines whether empty cells are converted to zeros. :param int head: (optional) Determines which index to use as keys, starting from 1 following the numeration of the spreadsheet. - :param int use_index: (optional) Determines whether to read records and headers from rows or columns. - 0 for rows, 1 for columns. - :param int first_index: (optional) row/col (depends on `use_index`) to start reading data from (inclusive) (1-based). - :param int last_index: (optional) row/col (depends on `use_index`) to stop reading at (inclusive) (1-based). + :param int first_index: (optional) row to start reading data from (inclusive) (1-based). + :param int last_index: (optional) row to stop reading at (inclusive) (1-based). :param str default_blank: (optional) Determines which value to use for blank cells, defaults to empty string. :param bool allow_underscores_in_numeric_literals: (optional) Allow @@ -627,23 +624,13 @@ def get_records( # noqa: C901 # this comment disables the complexity check for # 3 A11 B12 C13 # Read all rows from the sheet - >>> worksheet.get_records(use_index=0) + >>> worksheet.get_records() { {"A1": "A6", "B2": "B7", "C3": "C8"}, {"A1": "A11", "B2": "B12", "C3": "C13"} } - - >>> worksheet.get_records(use_index=1) - { - {"A1": "B2", "A6": "B7", "A11": "B12"}, - {"A1": "C3", "A6": "C8", "A11": "C13"} - } """ # some sanity checks - if use_index not in [0, 1]: - raise ValueError("use_index must be either 0 or 1") - if use_index == 1: # TODO: implement use_index=1 - raise NotImplementedError("use_index=1 is not implemented yet") if first_index is None: first_index = head + 1 From 4b7bfaedcfd2467bac7bcbb7fdfb8aa92783b94e Mon Sep 17 00:00:00 2001 From: alifeee Date: Sun, 5 Nov 2023 17:43:51 +0000 Subject: [PATCH 2/3] Revert "remove use_index and references to it" This reverts commit be127bd66b891e4e87f332af2e5722ffecae7250. --- gspread/worksheet.py | 21 +++++++++++++++++---- 1 file changed, 17 insertions(+), 4 deletions(-) diff --git a/gspread/worksheet.py b/gspread/worksheet.py index 58c81f0b4..7abf37af9 100644 --- a/gspread/worksheet.py +++ b/gspread/worksheet.py @@ -571,6 +571,7 @@ def get_records( # noqa: C901 # this comment disables the complexity check for self, empty2zero=False, head=1, + use_index=0, first_index=None, last_index=None, default_blank="", @@ -587,15 +588,17 @@ def get_records( # noqa: C901 # this comment disables the complexity check for Cell values are numericised (strings that can be read as ints or floats are converted), unless specified in numericise_ignore - Can be used to read data from rows, + Can be used to read data from rows (use_index=0) or columns (use_index=1) (default is 0), check the examples below for more details. :param bool empty2zero: (optional) Determines whether empty cells are converted to zeros. :param int head: (optional) Determines which index to use as keys, starting from 1 following the numeration of the spreadsheet. - :param int first_index: (optional) row to start reading data from (inclusive) (1-based). - :param int last_index: (optional) row to stop reading at (inclusive) (1-based). + :param int use_index: (optional) Determines whether to read records and headers from rows or columns. + 0 for rows, 1 for columns. + :param int first_index: (optional) row/col (depends on `use_index`) to start reading data from (inclusive) (1-based). + :param int last_index: (optional) row/col (depends on `use_index`) to stop reading at (inclusive) (1-based). :param str default_blank: (optional) Determines which value to use for blank cells, defaults to empty string. :param bool allow_underscores_in_numeric_literals: (optional) Allow @@ -624,13 +627,23 @@ def get_records( # noqa: C901 # this comment disables the complexity check for # 3 A11 B12 C13 # Read all rows from the sheet - >>> worksheet.get_records() + >>> worksheet.get_records(use_index=0) { {"A1": "A6", "B2": "B7", "C3": "C8"}, {"A1": "A11", "B2": "B12", "C3": "C13"} } + + >>> worksheet.get_records(use_index=1) + { + {"A1": "B2", "A6": "B7", "A11": "B12"}, + {"A1": "C3", "A6": "C8", "A11": "C13"} + } """ # some sanity checks + if use_index not in [0, 1]: + raise ValueError("use_index must be either 0 or 1") + if use_index == 1: # TODO: implement use_index=1 + raise NotImplementedError("use_index=1 is not implemented yet") if first_index is None: first_index = head + 1 From 16e0766c56f50465bc34413a51ae3a58d704fc43 Mon Sep 17 00:00:00 2001 From: alifeee Date: Sun, 5 Nov 2023 17:48:31 +0000 Subject: [PATCH 3/3] deprecate `use_index` in `get_records` --- gspread/worksheet.py | 32 ++++++++++++-------------------- 1 file changed, 12 insertions(+), 20 deletions(-) diff --git a/gspread/worksheet.py b/gspread/worksheet.py index 7abf37af9..fb99f7bfd 100644 --- a/gspread/worksheet.py +++ b/gspread/worksheet.py @@ -571,7 +571,7 @@ def get_records( # noqa: C901 # this comment disables the complexity check for self, empty2zero=False, head=1, - use_index=0, + use_index=None, first_index=None, last_index=None, default_blank="", @@ -588,17 +588,13 @@ def get_records( # noqa: C901 # this comment disables the complexity check for Cell values are numericised (strings that can be read as ints or floats are converted), unless specified in numericise_ignore - Can be used to read data from rows (use_index=0) or columns (use_index=1) (default is 0), - check the examples below for more details. - :param bool empty2zero: (optional) Determines whether empty cells are converted to zeros. :param int head: (optional) Determines which index to use as keys, starting from 1 following the numeration of the spreadsheet. - :param int use_index: (optional) Determines whether to read records and headers from rows or columns. - 0 for rows, 1 for columns. - :param int first_index: (optional) row/col (depends on `use_index`) to start reading data from (inclusive) (1-based). - :param int last_index: (optional) row/col (depends on `use_index`) to stop reading at (inclusive) (1-based). + :param int use_index: (optional) Deprecated. Please ignore. + :param int first_index: (optional) row to start reading data from (inclusive) (1-based). + :param int last_index: (optional) row to stop reading at (inclusive) (1-based). :param str default_blank: (optional) Determines which value to use for blank cells, defaults to empty string. :param bool allow_underscores_in_numeric_literals: (optional) Allow @@ -627,24 +623,20 @@ def get_records( # noqa: C901 # this comment disables the complexity check for # 3 A11 B12 C13 # Read all rows from the sheet - >>> worksheet.get_records(use_index=0) + >>> worksheet.get_records() { {"A1": "A6", "B2": "B7", "C3": "C8"}, {"A1": "A11", "B2": "B12", "C3": "C13"} } - - >>> worksheet.get_records(use_index=1) - { - {"A1": "B2", "A6": "B7", "A11": "B12"}, - {"A1": "C3", "A6": "C8", "A11": "C13"} - } """ - # some sanity checks - if use_index not in [0, 1]: - raise ValueError("use_index must be either 0 or 1") - if use_index == 1: # TODO: implement use_index=1 - raise NotImplementedError("use_index=1 is not implemented yet") + if use_index is not None: + deprecation_warning( + version="6.0.0", + msg="use_index in get_records does nothing." + "It will be removed. Please do not use it.", + ) + # some sanity checks if first_index is None: first_index = head + 1 elif first_index <= head: