1
# Copyright 2016 Feather Developers
3
# Licensed under the Apache License, Version 2.0 (the "License");
4
# you may not use this file except in compliance with the License.
5
# You may obtain a copy of the License at
7
# http://www.apache.org/licenses/LICENSE-2.0
9
# Unless required by applicable law or agreed to in writing, software
10
# distributed under the License is distributed on an "AS IS" BASIS,
11
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
# See the License for the specific language governing permissions and
13
# limitations under the License.
19
import feather.ext as ext
22
def write_dataframe(df, path):
24
Write a pandas.DataFrame to Feather format
26
writer = ext.FeatherWriter(path)
28
# TODO(wesm): pipeline conversion to Arrow memory layout
29
for i, name in enumerate(df.columns):
32
if not isinstance(name, six.string_types):
35
writer.write_array(name, col)
40
def read_dataframe(path, columns=None):
42
Read a pandas.DataFrame from Feather format
48
reader = ext.FeatherReader(path)
50
# TODO(wesm): pipeline conversion to Arrow memory layout
52
for i in range(reader.num_columns):
53
name, arr = reader.read_array(i)
57
return pd.DataFrame(data)