From 8bc2f4e4cfa9ad268fd0767cecad6d4b2936e371 Mon Sep 17 00:00:00 2001 From: Tim Swast Date: Fri, 17 Nov 2017 09:10:45 -0800 Subject: [PATCH 1/2] BigQuery: docs for Row.keys, items, values, and get functions. - Refactors items, keys to return iterators. - Copies values to prevent mutating the original row object. --- bigquery/google/cloud/bigquery/table.py | 88 +++++++++++++++++-------- 1 file changed, 59 insertions(+), 29 deletions(-) diff --git a/bigquery/google/cloud/bigquery/table.py b/bigquery/google/cloud/bigquery/table.py index ce68e18ef735..893bfb63c423 100644 --- a/bigquery/google/cloud/bigquery/table.py +++ b/bigquery/google/cloud/bigquery/table.py @@ -16,6 +16,7 @@ from __future__ import absolute_import +import copy import datetime import operator @@ -783,43 +784,72 @@ def __init__(self, values, field_to_index): self._xxx_field_to_index = field_to_index def values(self): - return self._xxx_values + """Return the values included in this row. - def keys(self): + Returns: + Sequence[object]: A sequence of length ``len(row)``. """ - Return keys as of a dict: - >>> Row(('a', 'b'), {'x': 0, 'y': 1}).keys() - ['x', 'y'] + return copy.deepcopy(self._xxx_values) + + def keys(self): + """Return the keys for using a row as a dict. + + Returns: + Sequence[str]: The keys corresponding to the columns of a row + + Examples: + + >>> list(Row(('a', 'b'), {'x': 0, 'y': 1}).keys()) + ['x', 'y'] """ - keys = self._xxx_field_to_index.keys() - return keys + return six.iterkeys(self._xxx_field_to_index) def items(self): + """Return items as ``(key, value)`` pairs. + + Returns: + Sequence[Tuple[str, object]]: + The ``(key, value)`` pairs representing this row. + + Examples: + + >>> list(Row(('a', 'b'), {'x': 0, 'y': 1}).items()) + [('x', 'a'), ('y', 'b')] """ - Return items as of a dict: - >>> Row(('a', 'b'), {'x': 0, 'y': 1}).items() - [('x', 'a'), ('y', 'b')] - """ - items = [ - (k, self._xxx_values[i]) - for k, i - in self._xxx_field_to_index.items() - ] - return items + for key, index in six.iteritems(self._xxx_field_to_index): + yield (key, copy.deepcopy(self._xxx_values[index])) def get(self, key, default=None): - """ - Return value under specified key - Defaults to None or specified default - if key does not exist: - >>> Row(('a', 'b'), {'x': 0, 'y': 1}).get('x') - 'a' - >>> Row(('a', 'b'), {'x': 0, 'y': 1}).get('z') - None - >>> Row(('a', 'b'), {'x': 0, 'y': 1}).get('z', '') - '' - >>> Row(('a', 'b'), {'x': 0, 'y': 1}).get('z', default = '') - '' + """Return a value for key, with a default value if it does not exist. + + Args: + key (str): The key of the column to access + default (object): + The default value to use if the key does not exist. (Defaults + to :data:`None`.) + + Returns: + object: + The value associated with the provided key, or a default value. + + Examples: + When the key exists, the value associated with it is returned. + + >>> Row(('a', 'b'), {'x': 0, 'y': 1}).get('x') + 'a' + + The default value is ``None`` when the key does not exist. + + >>> Row(('a', 'b'), {'x': 0, 'y': 1}).get('z') + None + + The default value can be overrided with the ``default`` parameter. + + >>> Row(('a', 'b'), {'x': 0, 'y': 1}).get('z', '') + '' + + >>> Row(('a', 'b'), {'x': 0, 'y': 1}).get('z', default = '') + '' """ index = self._xxx_field_to_index.get(key) if index is None: From d069e4bc954ea8f5ac414ede837b15e86b64ad52 Mon Sep 17 00:00:00 2001 From: Tim Swast Date: Fri, 17 Nov 2017 10:17:03 -0800 Subject: [PATCH 2/2] BQ: change Row.values() into a generator --- bigquery/google/cloud/bigquery/table.py | 3 ++- bigquery/tests/unit/test_table.py | 2 +- 2 files changed, 3 insertions(+), 2 deletions(-) diff --git a/bigquery/google/cloud/bigquery/table.py b/bigquery/google/cloud/bigquery/table.py index 893bfb63c423..9d61a84ea2b1 100644 --- a/bigquery/google/cloud/bigquery/table.py +++ b/bigquery/google/cloud/bigquery/table.py @@ -789,7 +789,8 @@ def values(self): Returns: Sequence[object]: A sequence of length ``len(row)``. """ - return copy.deepcopy(self._xxx_values) + for value in self._xxx_values: + yield copy.deepcopy(value) def keys(self): """Return the keys for using a row as a dict. diff --git a/bigquery/tests/unit/test_table.py b/bigquery/tests/unit/test_table.py index 49471f436be7..ffcf0b92ecaf 100644 --- a/bigquery/tests/unit/test_table.py +++ b/bigquery/tests/unit/test_table.py @@ -764,7 +764,7 @@ def test_row(self): self.assertEqual(row[1], 2) self.assertEqual(row['c'], 3) self.assertEqual(len(row), 3) - self.assertEqual(row.values(), VALUES) + self.assertEqual(tuple(row.values()), VALUES) self.assertEqual(set(row.keys()), set({'a': 1, 'b': 2, 'c': 3}.keys())) self.assertEqual(set(row.items()), set({'a': 1, 'b': 2, 'c': 3}.items()))