-
Notifications
You must be signed in to change notification settings - Fork 647
/
plotting.py
62 lines (50 loc) · 2.27 KB
/
plotting.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
# Licensed to Modin Development Team under one or more contributor license agreements.
# See the NOTICE file distributed with this work for additional information regarding
# copyright ownership. The Modin Development Team licenses this file to you under the
# Apache License, Version 2.0 (the "License"); you may not use this file except in
# compliance with the License. You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software distributed under
# the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF
# ANY KIND, either express or implied. See the License for the specific language
# governing permissions and limitations under the License.
"""Implement Pandas plotting API."""
from pandas import plotting as pdplot
from modin.utils import to_pandas
from .dataframe import DataFrame
def instancer(cls):
"""
Create a dummy instance each time this is imported.
This serves the purpose of allowing us to use all of pandas plotting methods
without aliasing and writing each of them ourselves.
"""
return cls()
@instancer
class Plotting(object):
"""Wrapper of Pandas plotting module."""
def __dir__(self):
"""Enable tab completion of plotting library."""
return dir(pdplot)
def __getattribute__(self, item):
"""Convert any Modin DataFrames in parameters to pandas so that they can be plotted normally."""
if hasattr(pdplot, item):
func = getattr(pdplot, item)
if callable(func):
def wrap_func(*args, **kwargs):
"""Convert Modin DataFrames to pandas then call the function."""
args = tuple(
arg if not isinstance(arg, DataFrame) else to_pandas(arg)
for arg in args
)
kwargs = {
kwd: val if not isinstance(val, DataFrame) else to_pandas(val)
for kwd, val in kwargs.items()
}
return func(*args, **kwargs)
return wrap_func
else:
return func
else:
return object.__getattribute__(self, item)