473,385 Members | 1,796 Online
Bytes | Software Development & Data Engineering Community
Post Job

Home Posts Topics Members FAQ

Join Bytes to post your question to a community of 473,385 software developers and data experts.

How to transfer data structure or class from Python to C/C++?

Hi friends,

I am a newer of Python. I want to ask below question:

I have a C/C++ application and I want to use Python as its extension.
To do that, I have to transfer some data structure from C/C++
application to Python and get some data structure from Python to C/C++
application. I have researched Python document, but the example only
describes how to transfer some simple data, such as integer,char,
etc.

Could you please guide me to do that? or tell me some document to have
a research?

Thanks.
Oct 16 '08 #1
10 3454
Hongtian:
Could you please guide me to do that? or tell me some document to have
a research?
You can start googling for:
- SWIG
- Boost.Python
- SIP
- ctypes (built-in module)
- And more.

Bye,
bearophile
Oct 16 '08 #2
On Oct 15, 8:08*pm, Hongtian <hongtian.i...@gmail.comwrote:
Hi friends,

I am a newer of Python. I want to ask below question:

I have a C/C++ application and I want to use Python as its extension.
To do that, I have to transfer some data structure from C/C++
application to Python and get some data structure from Python to C/C++
application. I have researched Python document, but the example only
describes how to transfer some simple data, such as integer,char,
etc.

Could you please guide me to do that? or tell me some document to have
a research?

Thanks.
Take this for what it's worth. If I understand correctly, you want
this:

struct info {
char* name;
char* address;
int age;
};

int main( ) {
info A, B;
python_run( "\
from urllib import urlget\n\
from mylib import populate_struct\n\
page= urlget( 'http://something' )\n\
populate_struct( page, A )\n\
populate_struct( page, B )\n" );
if( A.ageB.age ) {
something_in_C( );
}
return 0;
}

Am I on the right track? Do you have any questions so far?
Oct 16 '08 #3
Not exactly.

In my C/C++ application, I have following function or flow:

void func1(....)
{
call PyFunc(struct Tdemo, struct &Tdemo1);
}

I mean I want to invoke Python function 'PyFunc' and transfer a data
structure 'Tdemo' to this function. After some process in Python, I
want it return 'Tdemo1' back to the C/C++ application.

I research boost.python and think it is not a reasonable solution
because it make the C/C++ application too complex.

Thanks.

On Oct 16, 12:09*pm, "Aaron \"Castironpi\" Brady"
<castiro...@gmail.comwrote:
On Oct 15, 8:08*pm, Hongtian <hongtian.i...@gmail.comwrote:
Hi friends,
I am a newer of Python. I want to ask below question:
I have a C/C++ application and I want to use Python as its extension.
To do that, I have to transfer some data structure from C/C++
application to Python and get some data structure from Python to C/C++
application. I have researched Python document, but the example only
describes how to transfer some simple data, such as integer,char,
etc.
Could you please guide me to do that? or tell me some document to have
a research?
Thanks.

Take this for what it's worth. *If I understand correctly, you want
this:

struct info {
* char* name;
* char* address;
* int age;

};

int main( ) {
* info A, B;
* python_run( "\
from urllib import urlget\n\
from mylib import populate_struct\n\
page= urlget( 'http://something')\n\
populate_struct( page, A )\n\
populate_struct( page, B )\n" );
* if( A.ageB.age ) {
* * something_in_C( );
* }
* return 0;

}

Am I on the right track? *Do you have any questions so far?
Oct 16 '08 #4
On Oct 16, 9:10*am, Hongtian <hongtian.i...@gmail.comwrote:
Not exactly.

In my C/C++ application, I have following function or flow:

void func1(....)
{
* * call PyFunc(struct Tdemo, struct &Tdemo1);

}

I mean I want to invoke Python function 'PyFunc' and transfer a data
structure 'Tdemo' to this function. After some process in Python, I
want it return 'Tdemo1' back to the C/C++ application.

I research boost.python and think it is not a reasonable solution
because it make the C/C++ application too complex.

Thanks.
I am stumped. Here's what I have.

/C file:

typedef struct {
int a;
float b;
} TypeA;

static PyObject *
methA(PyObject *self, PyObject *args) {
TypeA a;
TypeA b;
PyObject* fun;
PyObject* res;
TypeA* pa;
TypeA* pb;

PyArg_ParseTuple( args, "O", &fun );
a.a= 10;
a.b= 20.5;
b.a= 30;
b.b= 40.5;
printf( "%p %p\n", &a, &b );

pa= &a;
pb= &b;

res= PyObject_CallFunction( fun, "II", &pa, &pb );
Py_DECREF( res );

return PyInt_FromLong( 0 );
}

/Py file:

import ng27ext

import ctypes as c
class TypeA( c.Structure ):
_fields_= [
( 'a', c.c_int ),
( 'b', c.c_float )
]

def exposed( obj1, obj2 ):
print 'in exposed'
print hex( obj1 ), hex( obj2 )
a= c.POINTER( TypeA ).from_address( obj1 )
print a
print a.contents

print ng27ext.methA( exposed )

/Output:

0021FD48 0021FD40
in exposed
0x21fd48 0x21fd40
<ctypes.LP_TypeA object at 0x009FF350>
<__main__.TypeA object at 0x009FF4E0>
0

Which is unexpected. The address on line 4 should be the contents of
'obj1', 0x21fd48, which it's not. I must not be using 'from_address'
properly.
Oct 16 '08 #5
On Oct 16, 9:10*am, Hongtian <hongtian.i...@gmail.comwrote:
Not exactly.

In my C/C++ application, I have following function or flow:

void func1(....)
{
* * call PyFunc(struct Tdemo, struct &Tdemo1);

}

I mean I want to invoke Python function 'PyFunc' and transfer a data
structure 'Tdemo' to this function. After some process in Python, I
want it return 'Tdemo1' back to the C/C++ application.

I research boost.python and think it is not a reasonable solution
because it make the C/C++ application too complex.

Thanks.

On Oct 16, 12:09*pm, "Aaron \"Castironpi\" Brady"

<castiro...@gmail.comwrote:
On Oct 15, 8:08*pm, Hongtian <hongtian.i...@gmail.comwrote:
Hi friends,
I am a newer of Python. I want to ask below question:
I have a C/C++ application and I want to use Python as its extension.
To do that, I have to transfer some data structure from C/C++
application to Python and get some data structure from Python to C/C++
application. I have researched Python document, but the example only
describes how to transfer some simple data, such as integer,char,
etc.
Could you please guide me to do that? or tell me some document to have
a research?
Thanks.
Did you have any luck?
Oct 17 '08 #6
On Oct 16, 9:10 am, Hongtian <hongtian.i...@gmail.comwrote:
Not exactly.

In my C/C++ application, I have following function or flow:

void func1(....)
{
call PyFunc(struct Tdemo, struct &Tdemo1);

}

I mean I want to invoke Python function 'PyFunc' and transfer a data
structure 'Tdemo' to this function. After some process in Python, I
want it return 'Tdemo1' back to the C/C++ application.

I research boost.python and think it is not a reasonable solution
because it make the C/C++ application too complex.

Thanks.

On Oct 16, 12:09 pm, "Aaron \"Castironpi\" Brady"

<castiro...@gmail.comwrote:
On Oct 15, 8:08 pm, Hongtian <hongtian.i...@gmail.comwrote:
Hi friends,
I am a newer of Python. I want to ask below question:
I have a C/C++ application and I want to use Python as its extension.
To do that, I have to transfer some data structure from C/C++
application to Python and get some data structure from Python to C/C++
application. I have researched Python document, but the example only
describes how to transfer some simple data, such as integer,char,
etc.
Could you please guide me to do that? or tell me some document to have
a research?
Thanks.
Did you have any luck?
Oct 17 '08 #7
On Oct 16, 9:10*am, Hongtian <hongtian.i...@gmail.comwrote:
Not exactly.

In my C/C++ application, I have following function or flow:

void func1(....)
{
* * call PyFunc(struct Tdemo, struct &Tdemo1);

}

I mean I want to invoke Python function 'PyFunc' and transfer a data
structure 'Tdemo' to this function. After some process in Python, I
want it return 'Tdemo1' back to the C/C++ application.

I research boost.python and think it is not a reasonable solution
because it make the C/C++ application too complex.

Thanks.
snip

Solution produced here. Includes dirty kludge, which will welcome
correction.

/C file:

#include <Python.h>

typedef struct {
int a;
float b;
} TypeA;

static PyObject *
methA(PyObject *self, PyObject *args) {
TypeA a;
TypeA b;
PyObject* fun;
PyObject* res;

PyArg_ParseTuple( args, "O", &fun );
a.a= 10;
a.b= 20.5;

res= PyObject_CallFunction( fun, "II", &a, &b );

printf( "%i %f\n", b.a, b.b );
Py_DECREF( res );

return PyInt_FromLong( 0 );
}

static PyMethodDef module_methods[] = {
{"methA", methA, METH_VARARGS, "No doc"},
{NULL, NULL, 0, NULL} /* Sentinel */
};
#ifndef PyMODINIT_FUNC /* declarations for DLL import/export */
#define PyMODINIT_FUNC void
#endif
PyMODINIT_FUNC
initng27ext(void)
{
PyObject* m;
m = Py_InitModule3("ng27ext", module_methods,
"Custom.");
if (m == NULL)
return;
}

/Py file:

import ng27ext

import ctypes as c
class TypeA( c.Structure ):
_fields_= [
( 'a', c.c_int ),
( 'b', c.c_float )
]

from _ctypes import _cast_addr
_data_cast= c.PYFUNCTYPE( c.py_object, c.c_void_p, c.py_object,
c.py_object)( _cast_addr ) #dirty kludge

def exposed( obj1, obj2 ):
cob1= _data_cast( obj1, None, c.POINTER( TypeA ) )
cob2= _data_cast( obj2, None, c.POINTER( TypeA ) )
print cob1.contents.a, cob1.contents.b
cob2.contents.a= c.c_int( 60 )
cob2.contents.b= c.c_float( 70.5 )
print cob2.contents.a, cob2.contents.b

print ng27ext.methA( exposed )

/Compile & link:

c:/programs/mingw/bin/gcc ng27ext.c -c -Ic:/programs/python25/include
c:/programs/mingw/bin/gcc -shared ng27ext.o -o ng27ext.pyd -Lc:/
programs/python25/libs -lpython25

/Output:

10 20.5
60 70.5
60 70.500000
0
Press any key to continue . . .

Oct 17 '08 #8
En Fri, 17 Oct 2008 20:03:44 -0300, Aaron "Castironpi" Brady
<ca********@gmail.comescribió:
On Oct 16, 9:10*am, Hongtian <hongtian.i...@gmail.comwrote:
>Not exactly.

In my C/C++ application, I have following function or flow:

void func1(....)
{
* * call PyFunc(struct Tdemo, struct &Tdemo1);

}

I mean I want to invoke Python function 'PyFunc' and transfer a data
structure 'Tdemo' to this function. After some process in Python, I
want it return 'Tdemo1' back to the C/C++ application.

I research boost.python and think it is not a reasonable solution
because it make the C/C++ application too complex.

Thanks.
snip

Solution produced here. Includes dirty kludge, which will welcome
correction.

/C file:

#include <Python.h>

typedef struct {
int a;
float b;
} TypeA;

static PyObject *
methA(PyObject *self, PyObject *args) {
TypeA a;
TypeA b;
PyObject* fun;
PyObject* res;

PyArg_ParseTuple( args, "O", &fun );
a.a= 10;
a.b= 20.5;

res= PyObject_CallFunction( fun, "II", &a, &b );

printf( "%i %f\n", b.a, b.b );
Py_DECREF( res );

return PyInt_FromLong( 0 );
}

static PyMethodDef module_methods[] = {
{"methA", methA, METH_VARARGS, "No doc"},
{NULL, NULL, 0, NULL} /* Sentinel */
};
#ifndef PyMODINIT_FUNC /* declarations for DLL import/export */
#define PyMODINIT_FUNC void
#endif
PyMODINIT_FUNC
initng27ext(void)
{
PyObject* m;
m = Py_InitModule3("ng27ext", module_methods,
"Custom.");
if (m == NULL)
return;
}

/Py file:

import ng27ext

import ctypes as c
class TypeA( c.Structure ):
_fields_= [
( 'a', c.c_int ),
( 'b', c.c_float )
]

from _ctypes import _cast_addr
_data_cast= c.PYFUNCTYPE( c.py_object, c.c_void_p, c.py_object,
c.py_object)( _cast_addr ) #dirty kludge

def exposed( obj1, obj2 ):
cob1= _data_cast( obj1, None, c.POINTER( TypeA ) )
cob2= _data_cast( obj2, None, c.POINTER( TypeA ) )
print cob1.contents.a, cob1.contents.b
cob2.contents.a= c.c_int( 60 )
cob2.contents.b= c.c_float( 70.5 )
print cob2.contents.a, cob2.contents.b

print ng27ext.methA( exposed )

/Compile & link:

c:/programs/mingw/bin/gcc ng27ext.c -c -Ic:/programs/python25/include
c:/programs/mingw/bin/gcc -shared ng27ext.o -o ng27ext.pyd -Lc:/
programs/python25/libs -lpython25

/Output:

10 20.5
60 70.5
60 70.500000
0
Press any key to continue . . .

--
http://mail.python.org/mailman/listinfo/python-list


--
Gabriel Genellina

Oct 21 '08 #9
On Oct 21, 12:46*am, "Gabriel Genellina" <gagsl-...@yahoo.com.ar>
wrote:
En Fri, 17 Oct 2008 20:03:44 -0300, Aaron "Castironpi" Brady *
<castiro...@gmail.comescribió:
On Oct 16, 9:10*am, Hongtian <hongtian.i...@gmail.comwrote:
Not exactly.
In my C/C++ application, I have following function or flow:
void func1(....)
{
* * call PyFunc(struct Tdemo, struct &Tdemo1);
}
I mean I want to invoke Python function 'PyFunc' and transfer a data
structure 'Tdemo' to this function. After some process in Python, I
want it return 'Tdemo1' back to the C/C++ application.
I research boost.python and think it is not a reasonable solution
because it make the C/C++ application too complex.
Thanks.
snip
Solution produced here. *Includes dirty kludge, which will welcome
correction.
snip
>
--
Gabriel Genellina
Hi Gabriel,
Sorry, did you have some questions about it?
Oct 21 '08 #10
En Tue, 21 Oct 2008 15:21:45 -0200, Aaron Brady <ca********@gmail.com>
escribió:
On Oct 21, 12:46*am, "Gabriel Genellina" <gagsl-...@yahoo.com.ar>
wrote:

Hi Gabriel,
Sorry, did you have some questions about it?
No, that empty message was posted by mistake, sorry.

--
Gabriel Genellina

Oct 22 '08 #11

This thread has been closed and replies have been disabled. Please start a new discussion.

Similar topics

2
by: ben moretti | last post by:
hi i'm learning python, and one area i'd use it for is data management in scientific computing. in the case i've tried i want to reformat a data file from a normalised list to a matrix with some...
4
by: spar | last post by:
I'm converting a Perl script to Python and have run into something I'm not sure how to do in Python. In Perl, I am running through a couple loops and inserting values directly into a complex...
5
by: Claudio Grondi | last post by:
Background information: --------------------------------- in order to monitor mainboard sensory data as fan speeds, temperatures, applications like SpeedFan http://www.almico.com/speedfan.php or...
3
by: Babbit | last post by:
I'm working with a bunch of configuration data that needs to be sent over from a workstation to a server. The old method was to simply memcpy structures into a buffer and send that across, however...
2
by: RAJ | last post by:
In our multi-tier application, we have several ASP.NET user controls which will update the same data source provided by middle tier logic. In this particular scenario we have one user control...
3
by: aurora | last post by:
This is an entry I just added to ASPN. It is a somewhat novel technique I have employed quite successfully in my code. I repost it here for more explosure and discussions. ...
3
by: tkirke | last post by:
How does one transfer a buffer object from python -c and back again (assuming the data gets modified)? I can't seem to get this or anything else to work, but am clueless as to what I'm doing wrong...
1
by: Rachel | last post by:
We recently upgraded to ASP.NET 2 AJAX Beta 2 an since we are encountering the following problem: STEPS: 1- navigate to a page containing a UpdatePanel using SERVER.TRANSFER 2- click on a...
4
by: Luvin lunch | last post by:
Hi, I've developed a worklist system in Access and I plan to deploy four copies of it to the four users that need it. I said I'll be deploying copies because there is no shared network in the...
1
by: CloudSolutions | last post by:
Introduction: For many beginners and individual users, requiring a credit card and email registration may pose a barrier when starting to use cloud servers. However, some cloud server providers now...
0
by: taylorcarr | last post by:
A Canon printer is a smart device known for being advanced, efficient, and reliable. It is designed for home, office, and hybrid workspace use and can also be used for a variety of purposes. However,...
0
by: Charles Arthur | last post by:
How do i turn on java script on a villaon, callus and itel keypad mobile phone
0
by: ryjfgjl | last post by:
If we have dozens or hundreds of excel to import into the database, if we use the excel import function provided by database editors such as navicat, it will be extremely tedious and time-consuming...
0
by: ryjfgjl | last post by:
In our work, we often receive Excel tables with data in the same format. If we want to analyze these data, it can be difficult to analyze them because the data is spread across multiple Excel files...
0
by: emmanuelkatto | last post by:
Hi All, I am Emmanuel katto from Uganda. I want to ask what challenges you've faced while migrating a website to cloud. Please let me know. Thanks! Emmanuel
0
BarryA
by: BarryA | last post by:
What are the essential steps and strategies outlined in the Data Structures and Algorithms (DSA) roadmap for aspiring data scientists? How can individuals effectively utilize this roadmap to progress...
1
by: Sonnysonu | last post by:
This is the data of csv file 1 2 3 1 2 3 1 2 3 1 2 3 2 3 2 3 3 the lengths should be different i have to store the data by column-wise with in the specific length. suppose the i have to...
0
by: Hystou | last post by:
There are some requirements for setting up RAID: 1. The motherboard and BIOS support RAID configuration. 2. The motherboard has 2 or more available SATA protocol SSD/HDD slots (including MSATA, M.2...

By using Bytes.com and it's services, you agree to our Privacy Policy and Terms of Use.

To disable or enable advertisements and analytics tracking please visit the manage ads & tracking page.