Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Unpin pycodestyle #25789

Merged
merged 10 commits into from
Mar 20, 2019
Merged
Show file tree
Hide file tree
Changes from 9 commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion environment.yml
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@ dependencies:
- hypothesis>=3.82
- isort
- moto
- pycodestyle=2.4
- pycodestyle
- pytest>=4.0.2
- pytest-mock
- sphinx
Expand Down
2 changes: 1 addition & 1 deletion pandas/_libs/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,4 +2,4 @@
# flake8: noqa

from .tslibs import (
iNaT, NaT, Timestamp, Timedelta, OutOfBoundsDatetime, Period)
iNaT, NaT, NaTType, Timestamp, Timedelta, OutOfBoundsDatetime, Period)
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Not sure if there's any objection to doing this, but if we didn't want to expose this would need to update type comments @jbrockmendel

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

whats the motivation here? I wouldn't want to expose this ideally. But its explicitly private so not really harmful.

2 changes: 1 addition & 1 deletion pandas/_libs/tslibs/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
# flake8: noqa

from .conversion import normalize_date, localize_pydatetime, tz_convert_single
from .nattype import NaT, iNaT, is_null_datetimelike
from .nattype import NaT, NaTType, iNaT, is_null_datetimelike
from .np_datetime import OutOfBoundsDatetime
from .period import Period, IncompatibleFrequency
from .timestamps import Timestamp
Expand Down
2 changes: 1 addition & 1 deletion pandas/_libs/tslibs/nattype.pyx
Original file line number Diff line number Diff line change
Expand Up @@ -353,7 +353,7 @@ class NaTType(_NaT):

.. versionadded:: 0.23.0
""")
day_name = _make_nan_func('day_name', # noqa:E128
day_name = _make_nan_func('day_name', # noqa:E128
"""
Return the day name of the Timestamp with specified locale.

Expand Down
6 changes: 5 additions & 1 deletion pandas/core/arrays/array_.py
Original file line number Diff line number Diff line change
@@ -1,8 +1,12 @@
from typing import Optional, Sequence, Union

import numpy as np

from pandas._libs import lib, tslibs

from pandas.core.dtypes.common import (
is_datetime64_ns_dtype, is_extension_array_dtype, is_timedelta64_ns_dtype)
from pandas.core.dtypes.dtypes import registry
from pandas.core.dtypes.dtypes import ExtensionDtype, registry

from pandas import compat

Expand Down
8 changes: 5 additions & 3 deletions pandas/core/arrays/base.py
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@
without warning.
"""
import operator
from typing import Any, Callable, Optional, Sequence, Tuple, Union

import numpy as np

Expand All @@ -15,6 +16,7 @@
from pandas.util._decorators import Appender, Substitution

from pandas.core.dtypes.common import is_list_like
from pandas.core.dtypes.dtypes import ExtensionDtype
from pandas.core.dtypes.generic import ABCIndexClass, ABCSeries
from pandas.core.dtypes.missing import isna

Expand Down Expand Up @@ -365,7 +367,7 @@ def isna(self):
raise AbstractMethodError(self)

def _values_for_argsort(self):
# type: () -> ndarray
# type: () -> np.ndarray
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

we can switch to the py3 style now i think (here or later)

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yea planning to do later to minimize diff

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

great

"""
Return values for sorting.

Expand Down Expand Up @@ -597,7 +599,7 @@ def searchsorted(self, value, side="left", sorter=None):
return arr.searchsorted(value, side=side, sorter=sorter)

def _values_for_factorize(self):
# type: () -> Tuple[ndarray, Any]
# type: () -> Tuple[np.ndarray, Any]
"""
Return an array and missing value suitable for factorization.

Expand All @@ -622,7 +624,7 @@ def _values_for_factorize(self):
return self.astype(object), np.nan

def factorize(self, na_sentinel=-1):
# type: (int) -> Tuple[ndarray, ExtensionArray]
# type: (int) -> Tuple[np.ndarray, ExtensionArray]
"""
Encode the extension array as an enumerated type.

Expand Down
9 changes: 5 additions & 4 deletions pandas/core/arrays/datetimelike.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,10 +2,11 @@
from datetime import datetime, timedelta
import operator
import warnings
from typing import Any, Sequence, Tuple, Union

import numpy as np

from pandas._libs import NaT, algos, iNaT, lib
from pandas._libs import NaT, NaTType, algos, iNaT, lib, Timestamp
from pandas._libs.tslibs.period import (
DIFFERENT_FREQ, IncompatibleFrequency, Period)
from pandas._libs.tslibs.timedeltas import Timedelta, delta_to_nanoseconds
Expand Down Expand Up @@ -350,7 +351,7 @@ def __iter__(self):

@property
def asi8(self):
# type: () -> ndarray
# type: () -> np.ndarray
"""
Integer representation of the values.

Expand Down Expand Up @@ -461,10 +462,10 @@ def __getitem__(self, key):
def __setitem__(
self,
key, # type: Union[int, Sequence[int], Sequence[bool], slice]
value, # type: Union[NaTType, Scalar, Sequence[Scalar]]
value, # type: Union[NaTType, Any, Sequence[Any]]
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

does Any not encompan NaTType here?

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Valid question. I mostly changed this to get it to pass since Scalar isn't a real thing as indicated by subsequent TODO. Think I should just remove Any altogether for the time being?

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

no it would fail for that. What we need is a type that is an allowed datetime value, e.g: string, datetime / Timestamp, NaT). These can of course be done later, but should start setting up a pandas.typing i think.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yah, I'd rather have an import from pandas.typing and avoid imports that aren't "really" used (i.e. NaTType).

):
# type: (...) -> None
# I'm fudging the types a bit here. The "Scalar" above really depends
# I'm fudging the types a bit here. "Any" above really depends
# on type(self). For PeriodArray, it's Period (or stuff coercible
# to a period in from_sequence). For DatetimeArray, it's Timestamp...
# I don't know if mypy can do that, possibly with Generics.
Expand Down
1 change: 1 addition & 0 deletions pandas/core/arrays/datetimes.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@
from datetime import datetime, time, timedelta
import textwrap
import warnings
from typing import Union

import numpy as np
from pytz import utc
Expand Down
2 changes: 1 addition & 1 deletion pandas/core/arrays/integer.py
Original file line number Diff line number Diff line change
Expand Up @@ -510,7 +510,7 @@ def value_counts(self, dropna=True):
return Series(array, index=index)

def _values_for_argsort(self):
# type: () -> ndarray
# type: () -> np.ndarray
"""Return values for sorting.

Returns
Expand Down
12 changes: 8 additions & 4 deletions pandas/core/arrays/period.py
Original file line number Diff line number Diff line change
@@ -1,11 +1,12 @@
# -*- coding: utf-8 -*-
from datetime import timedelta
import operator
from typing import Any, Callable, Optional, Sequence, Union

import numpy as np

from pandas._libs.tslibs import (
NaT, frequencies as libfrequencies, iNaT, period as libperiod)
NaT, NaTType, frequencies as libfrequencies, iNaT, period as libperiod)
from pandas._libs.tslibs.fields import isleapyear_arr
from pandas._libs.tslibs.period import (
DIFFERENT_FREQ, IncompatibleFrequency, Period, get_period_field_arr,
Expand All @@ -23,7 +24,7 @@
from pandas.core.dtypes.missing import isna, notna

import pandas.core.algorithms as algos
from pandas.core.arrays import datetimelike as dtl
from pandas.core.arrays import datetimelike as dtl, ExtensionArray
import pandas.core.common as com

from pandas.tseries import frequencies
Expand Down Expand Up @@ -536,11 +537,14 @@ def _sub_period(self, other):
@Appender(dtl.DatetimeLikeArrayMixin._addsub_int_array.__doc__)
def _addsub_int_array(
self,
other, # type: Union[Index, ExtensionArray, np.ndarray[int]]
op # type: Callable[Any, Any]
other, # type: Union[ExtensionArray, np.ndarray[int]]
op # type: Callable[Any, Any]
):
# type: (...) -> PeriodArray

# TODO: ABCIndexClass is a valid type for other but had to be excluded
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Comment explains it, but just to clarify this PR doesn't necessarily check that comments are correct as much as gets them to pass linting. I figure it makes sense to validate the comments themselves when moving over to Py3 syntax, so this was the quick way of getting this to pass

# due to length of Py2 compatability comment; add back in once migrated
# to Py3 syntax
assert op in [operator.add, operator.sub]
if op is operator.sub:
other = -other
Expand Down
5 changes: 3 additions & 2 deletions pandas/core/arrays/sparse.py
Original file line number Diff line number Diff line change
Expand Up @@ -7,12 +7,13 @@
import operator
import re
import warnings
from typing import Any, Callable, Union

import numpy as np

from pandas._libs import index as libindex, lib
import pandas._libs.sparse as splib
from pandas._libs.sparse import BlockIndex, IntIndex
from pandas._libs.sparse import BlockIndex, IntIndex, SparseIndex
from pandas._libs.tslibs import NaT
import pandas.compat as compat
from pandas.compat.numpy import function as nv
Expand Down Expand Up @@ -372,7 +373,7 @@ def _subtype_with_str(self):


def _get_fill(arr):
# type: (SparseArray) -> ndarray
# type: (SparseArray) -> np.ndarray
"""
Create a 0-dim ndarray containing the fill value

Expand Down
1 change: 1 addition & 0 deletions pandas/core/base.py
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@
from pandas.util._decorators import Appender, Substitution, cache_readonly
from pandas.util._validators import validate_bool_kwarg

from pandas.core.arrays import ExtensionArray
from pandas.core.dtypes.common import (
is_datetime64_ns_dtype, is_datetime64tz_dtype, is_datetimelike,
is_extension_array_dtype, is_extension_type, is_list_like, is_object_dtype,
Expand Down
1 change: 1 addition & 0 deletions pandas/core/common.py
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@
from collections import OrderedDict
from datetime import datetime, timedelta
from functools import partial
from typing import Any
import inspect

import numpy as np
Expand Down
4 changes: 3 additions & 1 deletion pandas/core/dtypes/base.py
Original file line number Diff line number Diff line change
@@ -1,4 +1,6 @@
"""Extend pandas with custom array types"""
from typing import List, Optional, Type

import numpy as np

from pandas.errors import AbstractMethodError
Expand Down Expand Up @@ -211,7 +213,7 @@ def __str__(self):

@property
def type(self):
# type: () -> type
# type: () -> Type
"""
The scalar type for the array, e.g. ``int``

Expand Down
2 changes: 1 addition & 1 deletion pandas/core/dtypes/dtypes.py
Original file line number Diff line number Diff line change
Expand Up @@ -937,7 +937,7 @@ def construct_from_string(cls, string):

if (string.lower() == 'interval' or
cls._match.search(string) is not None):
return cls(string)
return cls(string)

msg = ('Incorrectly formatted string passed to constructor. '
'Valid formats include Interval or Interval[dtype] '
Expand Down
1 change: 1 addition & 0 deletions pandas/core/frame.py
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@
import sys
import warnings
from textwrap import dedent
from typing import List, Union

import numpy as np
import numpy.ma as ma
Expand Down
11 changes: 6 additions & 5 deletions pandas/core/groupby/groupby.py
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@ class providing the base-class of operations.
from functools import partial, wraps
import types
import warnings
from typing import Optional, Type

import numpy as np

Expand Down Expand Up @@ -1040,7 +1041,7 @@ def _bool_agg(self, val_test, skipna):
"""

def objs_to_bool(vals):
# type: (np.ndarray) -> (np.ndarray, typing.Type)
# type: (np.ndarray) -> (np.ndarray, Type)
if is_object_dtype(vals):
vals = np.array([bool(x) for x in vals])
else:
Expand All @@ -1049,7 +1050,7 @@ def objs_to_bool(vals):
return vals.view(np.uint8), np.bool

def result_to_bool(result, inference):
# type: (np.ndarray, typing.Type) -> np.ndarray
# type: (np.ndarray, Type) -> np.ndarray
return result.astype(inference, copy=False)

return self._get_cythonized_result('group_any_all', self.grouper,
Expand Down Expand Up @@ -1738,7 +1739,7 @@ def quantile(self, q=0.5, interpolation='linear'):
"""

def pre_processor(vals):
# type: (np.ndarray) -> (np.ndarray, Optional[typing.Type])
# type: (np.ndarray) -> (np.ndarray, Optional[Type])
if is_object_dtype(vals):
raise TypeError("'quantile' cannot be performed against "
"'object' dtypes!")
Expand All @@ -1753,7 +1754,7 @@ def pre_processor(vals):
return vals, inference

def post_processor(vals, inference):
# type: (np.ndarray, Optional[typing.Type]) -> np.ndarray
# type: (np.ndarray, Optional[Type]) -> np.ndarray
if inference:
# Check for edge case
if not (is_integer_dtype(inference) and
Expand Down Expand Up @@ -2016,7 +2017,7 @@ def _get_cythonized_result(self, how, grouper, aggregate=False,
Function to be applied to result of Cython function. Should accept
an array of values as the first argument and type inferences as its
second argument, i.e. the signature should be
(ndarray, typing.Type).
(ndarray, Type).
**kwargs : dict
Extra arguments to be passed back to Cython funcs

Expand Down
1 change: 1 addition & 0 deletions pandas/core/indexes/base.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@
import operator
from textwrap import dedent
import warnings
from typing import Union

import numpy as np

Expand Down
8 changes: 6 additions & 2 deletions pandas/core/internals/blocks.py
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@
import inspect
import re
import warnings
from typing import Any, List

import numpy as np

Expand Down Expand Up @@ -1826,8 +1827,11 @@ def interpolate(self, method='pad', axis=0, inplace=False, limit=None,
limit=limit),
placement=self.mgr_locs)

def shift(self, periods, axis=0, fill_value=None):
# type: (int, Optional[BlockPlacement], Any) -> List[ExtensionBlock]
def shift(self,
periods, # type: int
axis=0, # type: libinternals.BlockPlacement
fill_value=None): # type: Any
# type: (...) -> List[ExtensionBlock]
"""
Shift the block by `periods`.

Expand Down
2 changes: 2 additions & 0 deletions pandas/core/internals/managers.py
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@
import itertools
import operator
import re
from typing import List, Optional, Union

import numpy as np

Expand All @@ -17,6 +18,7 @@
from pandas.core.dtypes.common import (
_NS_DTYPE, is_datetimelike_v_numeric, is_extension_array_dtype,
is_extension_type, is_list_like, is_numeric_v_string_like, is_scalar)
from pandas.core.dtypes.dtypes import ExtensionDtype
import pandas.core.dtypes.concat as _concat
from pandas.core.dtypes.generic import ABCExtensionArray, ABCSeries
from pandas.core.dtypes.missing import isna
Expand Down
1 change: 0 additions & 1 deletion pandas/io/formats/format.py
Original file line number Diff line number Diff line change
Expand Up @@ -440,7 +440,6 @@ def _chk_truncate(self):
max_rows = self.max_rows

if max_cols == 0 or max_rows == 0: # assume we are in the terminal
# (why else = 0)
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Hanging comment was causing a lint error. I figured it didn't add much so easier to remove than reword

(w, h) = get_terminal_size()
self.w = w
self.h = h
Expand Down
5 changes: 3 additions & 2 deletions pandas/tests/frame/test_alter_axes.py
Original file line number Diff line number Diff line change
Expand Up @@ -201,7 +201,8 @@ def test_set_index_pass_arrays_duplicate(self, frame_of_index_cols, drop,
# need to adapt first drop for case that both keys are 'A' --
# cannot drop the same column twice;
# use "is" because == would give ambiguous Boolean error for containers
first_drop = False if (keys[0] is 'A' and keys[1] is 'A') else drop
first_drop = False if (
keys[0] is 'A' and keys[1] is 'A') else drop # noqa: F632
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

F632 is ignored because it calls out using is for equality comparisons. You can see in the note above though that this test intentionally uses is instead of the equality operator

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

IIRC interning of short strings is a CPython implementation detail. Are we sure we want to rely on that?


# to test against already-tested behaviour, we add sequentially,
# hence second append always True; must wrap keys in list, otherwise
Expand Down Expand Up @@ -1272,7 +1273,7 @@ def test_rename_axis_style_raises(self):
df.rename(id, mapper=id)

def test_reindex_api_equivalence(self):
# equivalence of the labels/axis and index/columns API's
# equivalence of the labels/axis and index/columns API's
df = DataFrame([[1, 2, 3], [3, 4, 5], [5, 6, 7]],
index=['a', 'b', 'c'],
columns=['d', 'e', 'f'])
Expand Down
2 changes: 1 addition & 1 deletion pandas/tests/groupby/test_apply.py
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@


def test_apply_issues():
# GH 5788
# GH 5788

s = """2011.05.16,00:00,1.40893
2011.05.16,01:00,1.40760
Expand Down
Loading