2017-06-28 22:08:39 +08:00
|
|
|
#include <iostream>
|
2017-07-01 22:46:48 +08:00
|
|
|
#include <memory>
|
|
|
|
#include <vector>
|
2017-07-02 23:43:26 +08:00
|
|
|
#include <xlntarrow.hpp>
|
2017-07-01 22:46:48 +08:00
|
|
|
#include <python_streambuf.hpp>
|
2017-06-28 22:08:39 +08:00
|
|
|
#include <Python.h>
|
|
|
|
|
2017-07-01 22:46:48 +08:00
|
|
|
PyObject *xlsx2arrow(PyObject *file)
|
|
|
|
{
|
|
|
|
boost::python::handle<> boost_file_handle(file);
|
|
|
|
boost::python::object boost_file(boost_file_handle);
|
|
|
|
boost_adaptbx::python::streambuf buffer(boost_file);
|
|
|
|
std::istream stream(&buffer);
|
|
|
|
std::shared_ptr<arrow::Schema> schema;
|
|
|
|
std::vector<std::shared_ptr<arrow::Column>> columns;
|
|
|
|
arrow::Table table(schema, columns);
|
|
|
|
xlnt::arrow::xlsx2arrow(stream, table);
|
|
|
|
|
|
|
|
Py_RETURN_NONE;
|
|
|
|
}
|
2017-06-28 22:08:39 +08:00
|
|
|
|
|
|
|
extern "C" {
|
|
|
|
|
|
|
|
/*
|
2017-06-28 22:20:22 +08:00
|
|
|
* Implements XLSX->pyarrow table function.
|
2017-06-28 22:08:39 +08:00
|
|
|
*/
|
2017-06-28 22:20:22 +08:00
|
|
|
PyDoc_STRVAR(xlntpyarrow_xlsx2arrow_doc, "xlsx2arrow(in_file)\
|
2017-06-28 22:08:39 +08:00
|
|
|
\
|
2017-06-28 22:20:22 +08:00
|
|
|
Returns an arrow table representing the given XLSX file object.");
|
2017-06-28 22:08:39 +08:00
|
|
|
|
2017-07-01 22:46:48 +08:00
|
|
|
PyObject *xlntpyarrow_xlsx2arrow(PyObject *self, PyObject *args, PyObject *kwargs)
|
|
|
|
{
|
|
|
|
PyObject *file = NULL;
|
|
|
|
static char* keywords[] = { "file", NULL };
|
2017-06-28 22:20:22 +08:00
|
|
|
|
2017-07-01 22:46:48 +08:00
|
|
|
if (!PyArg_ParseTupleAndKeywords(args, kwargs, "O", keywords, &file))
|
|
|
|
{
|
2017-06-28 22:20:22 +08:00
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2017-07-01 22:46:48 +08:00
|
|
|
return xlsx2arrow(file);
|
2017-06-28 22:20:22 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Implements pyarrow table->XLSX function.
|
|
|
|
*/
|
|
|
|
PyDoc_STRVAR(xlntpyarrow_arrow2xlsx_doc, "arrow2xlsx(table, out_file)\
|
|
|
|
\
|
|
|
|
Writes the given arrow table to out_file as an XLSX file.");
|
|
|
|
|
2017-07-01 22:46:48 +08:00
|
|
|
PyObject *xlntpyarrow_arrow2xlsx(PyObject *self, PyObject *args, PyObject *kwargs)
|
|
|
|
{
|
2017-06-28 22:08:39 +08:00
|
|
|
PyObject *obj = NULL;
|
2017-07-01 22:46:48 +08:00
|
|
|
static char* keywords[] = { "obj", NULL };
|
2017-06-28 22:08:39 +08:00
|
|
|
|
2017-07-01 22:46:48 +08:00
|
|
|
if (!PyArg_ParseTupleAndKeywords(args, kwargs, "Oi", keywords, &obj))
|
|
|
|
{
|
2017-06-28 22:08:39 +08:00
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
Py_RETURN_NONE;
|
|
|
|
}
|
|
|
|
|
2017-07-01 22:46:48 +08:00
|
|
|
static PyMethodDef xlntpyarrow_functions[] =
|
|
|
|
{
|
2017-06-28 22:20:22 +08:00
|
|
|
{ "xlsx2arrow", (PyCFunction)xlntpyarrow_xlsx2arrow, METH_VARARGS | METH_KEYWORDS, xlntpyarrow_xlsx2arrow_doc },
|
|
|
|
{ "arrow2xlsx", (PyCFunction)xlntpyarrow_arrow2xlsx, METH_VARARGS | METH_KEYWORDS, xlntpyarrow_arrow2xlsx_doc },
|
2017-06-28 22:08:39 +08:00
|
|
|
{ NULL, NULL, 0, NULL } /* marks end of array */
|
|
|
|
};
|
|
|
|
|
2017-07-01 22:46:48 +08:00
|
|
|
int exec_xlntpyarrow(PyObject *module)
|
|
|
|
{
|
2017-06-28 22:08:39 +08:00
|
|
|
PyModule_AddFunctions(module, xlntpyarrow_functions);
|
|
|
|
|
2017-06-28 22:20:22 +08:00
|
|
|
PyModule_AddStringConstant(module, "__author__", "Thomas Fussell");
|
|
|
|
PyModule_AddStringConstant(module, "__version__", "0.9.0");
|
2017-06-28 22:08:39 +08:00
|
|
|
PyModule_AddIntConstant(module, "year", 2017);
|
|
|
|
|
2017-07-01 22:46:48 +08:00
|
|
|
return 0;
|
2017-06-28 22:08:39 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
PyDoc_STRVAR(xlntpyarrow_doc, "The xlntpyarrow module");
|
|
|
|
|
2017-07-01 22:46:48 +08:00
|
|
|
static PyModuleDef_Slot xlntpyarrow_slots[] =
|
|
|
|
{
|
2017-06-28 22:08:39 +08:00
|
|
|
{ Py_mod_exec, exec_xlntpyarrow },
|
|
|
|
{ 0, NULL }
|
|
|
|
};
|
|
|
|
|
2017-07-01 22:46:48 +08:00
|
|
|
static PyModuleDef xlntpyarrow_def =
|
|
|
|
{
|
2017-06-28 22:08:39 +08:00
|
|
|
PyModuleDef_HEAD_INIT,
|
|
|
|
"xlntpyarrow",
|
|
|
|
xlntpyarrow_doc,
|
|
|
|
0, /* m_size */
|
|
|
|
NULL, /* m_methods */
|
|
|
|
xlntpyarrow_slots,
|
|
|
|
NULL, /* m_traverse */
|
|
|
|
NULL, /* m_clear */
|
|
|
|
NULL, /* m_free */
|
|
|
|
};
|
|
|
|
|
2017-07-01 22:46:48 +08:00
|
|
|
PyMODINIT_FUNC PyInit_xlntpyarrow()
|
|
|
|
{
|
2017-06-28 22:08:39 +08:00
|
|
|
return PyModuleDef_Init(&xlntpyarrow_def);
|
|
|
|
}
|
|
|
|
|
2017-07-01 22:46:48 +08:00
|
|
|
} // extern "C"
|