Модераторы: Daevaorn

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> из питона на с++ 
:(
    Опции темы
mrgloom
Дата 26.4.2012, 13:11 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 829
Регистрация: 8.6.2011

Репутация: нет
Всего: нет



есть пара файлов на питоне *.py
надо их автоматом перевести на с++ или же собрать библиотеку или длл чтобы можно было из с++ вызывать.
там подключаются следующие модули
Код

import socket
import string
import struct
import sys


возможно ли?
PM MAIL   Вверх
kosmonaFFFt
Дата 26.4.2012, 13:15 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 538
Регистрация: 14.4.2008
Где: Иннополис

Репутация: нет
Всего: 5



Можно заюзать boost::python или просто в C коде создать интерпретатор питона и выполнять скрипты...


--------------------
user posted image
PM MAIL ICQ   Вверх
mrgloom
Дата 26.4.2012, 13:29 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 829
Регистрация: 8.6.2011

Репутация: нет
Всего: нет



Цитата

boost::python

это для выполнения участков кода? а можно подключать питоновые библиотеки? интерпретатор нужно с собой таскать?

Цитата

просто в C коде создать интерпретатор питона и выполнять скрипты

имеется ввиду самописный интерпретатор?

PM MAIL   Вверх
mrgloom
Дата 26.4.2012, 14:01 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 829
Регистрация: 8.6.2011

Репутация: нет
Всего: нет



а с помощью py2exe нельзя сделать dll?
PM MAIL   Вверх
mrgloom
Дата 26.4.2012, 14:34 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 829
Регистрация: 8.6.2011

Репутация: нет
Всего: нет



http://docs.python.org/extending/embedding.html

вот нашел, но я не понял с программой надо все таки таскать интерпретатор в таком случае или нет?
PM MAIL   Вверх
rsm
Дата 27.4.2012, 03:18 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник Клуба
Сообщений: 999
Регистрация: 16.3.2005

Репутация: нет
Всего: 62



Цитата(mrgloom @  26.4.2012,  16:34 Найти цитируемый пост)
я не понял с программой надо все таки таскать интерпретатор в таком случае или нет?

Надо, причём свой собственный, который напишешь для обработки скриптов.
PM MAIL   Вверх
mrgloom
Дата 27.4.2012, 09:41 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 829
Регистрация: 8.6.2011

Репутация: нет
Всего: нет



Цитата(rsm @  27.4.2012,  03:18 Найти цитируемый пост)
Надо, причём свой собственный, который напишешь для обработки скриптов. 


ну по-моему это бред, зачем писать парсер+библиотеки, если питон как бы уже имеет среду выполнения.

там(выше в постах) вроде бы есть методы как вызывать код питона из кода с++, но для меня остался открытым вопрос нужно
ли будет устанавливать интерпретатор питона на машине на которой будет запускаться программа?
или например можно как то "вложить" это сразу всё в код, я хочу статическую линковку, т.е. на выходе только 1 .exe.
или например надо за собой таскать что то навроде python27.dll или подключать python27.lib?

так же не очень понятно как использовать уже готовый код на питоне, ну вот у меня допустим есть 2 .py файла,
которые писал не я, но я хочу использовать код который там, там есть import'ы (вроде бы стандартные), но меня все равно это смущает,
т.к. т.к. это потянется все в код, как я пониаю?
потом там есть классы и функции не понятно как это привязать к классам и функциям на с++.

т.е. в идеале я вообще хотел бы так 

с++ код

Код

class my_python;
my_python.DoSomeFunction(int f, ...);


т.е. чтобы весь этот питон код был скрыт от меня и лучше бы наверно в отдельную библиотеку.
PM MAIL   Вверх
kosmonaFFFt
Дата 27.4.2012, 10:27 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 538
Регистрация: 14.4.2008
Где: Иннополис

Репутация: нет
Всего: 5



Свой интерпретатор ИМХО писать не надо, достаточно прилинковаться к питоновской билиотеке, не уверен что стандартные питоновские либы просто так заработают, скорее всего придется какие-то файлы питона за собой тянуть...


--------------------
user posted image
PM MAIL ICQ   Вверх
mrgloom
Дата 27.4.2012, 10:35 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 829
Регистрация: 8.6.2011

Репутация: нет
Всего: нет



http://docs.python.org/release/2.5.2/ext/callingPython.html
http://www.codeproject.com/Articles/11805/...n-in-C-C-Part-I
http://www.codeproject.com/Articles/11843/...-in-C-C-Part-II
вот еще какие-то методы, но все вышеперечисленные вопрсы они не разъяснили.

пока попробую shedskin может получится просто перегнать код в с++

 UPD: shedskin лажа полная, там столько ограничений, что только головная боль.

Это сообщение отредактировал(а) mrgloom - 27.4.2012, 12:11
PM MAIL   Вверх
mrgloom
Дата 27.4.2012, 11:04 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 829
Регистрация: 8.6.2011

Репутация: нет
Всего: нет



ладно давайте вообще рассмотрим самый простой пример 

Код

# hello.py
def my_sum(x,y):
    print "Hello World!"
    return x*x+y


как мне вызвать этот код? из с++?

т.е. я должен получить что то типа

Код

int sum= py.my_sum(x,y);

PM MAIL   Вверх
rsm
Дата 27.4.2012, 18:33 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник Клуба
Сообщений: 999
Регистрация: 16.3.2005

Репутация: нет
Всего: 62



Цитата(mrgloom @  27.4.2012,  11:41 Найти цитируемый пост)
зачем писать парсер+библиотеки, если питон как бы уже имеет среду выполнения

Парсер писать не надо. Надо будет линковать к своей программе библиотеку Python. Т.е. по сути получится тот же самый интерпретатор, только без интерактивного режима и выполняющий только одну конкретную задачу.

Цитата(mrgloom @  27.4.2012,  11:41 Найти цитируемый пост)
можно как то "вложить" это сразу всё в код, я хочу статическую линковку, т.е. на выходе только 1 .exe

Можно слинковать библиотеку Python статически. Тогда получится один бинарник (интерпретатор), которые будет выполнять передаваемые ему в качестве аргументов (или как-то ещё) скрипты.

Цитата(mrgloom @  27.4.2012,  13:04 Найти цитируемый пост)
ладно давайте вообще рассмотрим самый простой пример / как мне вызвать этот код? из с++?

Как-то так (исходники примера в аттаче).

Код

#include <stdio.h>
#include <Python.h>

#define FIRST_ARG (10)             /* первый аргумент x */
#define SECOND_ARG (20)            /* второй аргумент y */
#define MODULE_FILE ("hello.py")   /* файл с кодом Python */
#define FUNCTION_NAME ("my_sum")   /* название функции */

int main(int argc, char **argv)
{
    FILE* fp;
    PyObject *result, *module, *globals, *function;

    /* инициализируем интерпретатор */

    Py_Initialize();

    /* открываем файл с кодом Python */

    fp = fopen(MODULE_FILE, "r");

    /* прогоняем код через интерпретатор */

    PyRun_SimpleFile(fp, MODULE_FILE);

    /* импортируем модуль __main__ из выполненного кода */

    module = PyImport_AddModule("__main__");

    /* получаем словарь со всеми экспортируемыми модулем объектами */
    
    globals = PyModule_GetDict(module);

    /* получаем указатель на функцию */

    function = PyDict_GetItemString(globals, FUNCTION_NAME);

    /* вызываем функцию, аргументы - два целых числа типа `int' */

    result = PyObject_CallFunction(function, "ii", FIRST_ARG, SECOND_ARG);

    /* выводим результат вызова функции */

    printf("result = %ld\n", PyInt_AsLong(result));

    /* завершаем работу интерпретатора */

    Py_Finalize();

    /* закрываем файл */
    
    fclose(fp);

    return 0;
}

Это самый примитивнейший вариант, из которого выпилены все проверки результатов вызовов функций и весь код по освобождению занятой памяти. В нормальном варианте всё должно проверяться и память - освобождаться. И тем не менее, как бы глупо это ни звучало, это вполне полноценный интерпретатор Python.

Это сообщение отредактировал(а) rsm - 28.4.2012, 03:26

Присоединённый файл ( Кол-во скачиваний: 2 )
Присоединённый файл  embedded_python_example.zip 1,45 Kb
PM MAIL   Вверх
mrgloom
Дата 28.4.2012, 12:01 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 829
Регистрация: 8.6.2011

Репутация: нет
Всего: нет



Цитата

Можно слинковать библиотеку Python статически.

все таки я не очень понял про что вы. это присоединить к проекту на с++ исходный код интерпретатора?
так вспомогательные функции (которые лежат в папке Lib)  опять же написаны на питоне.

насчет кода , в итоге я так и сделал, только мне приходится таскать с собой python27.dll, необходимые файлы .py из Lib и свои .py файлы из которых я вызываю функцию, в принципе и так можно, но хотелось бы все это запаковать в один .exe файл.
PM MAIL   Вверх
rsm
Дата 28.4.2012, 15:35 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник Клуба
Сообщений: 999
Регистрация: 16.3.2005

Репутация: нет
Всего: 62



Цитата(mrgloom @  28.4.2012,  14:01 Найти цитируемый пост)
присоединить к проекту на с++ исходный код интерпретатора?

smile

Цитата(mrgloom @  28.4.2012,  14:01 Найти цитируемый пост)
в принципе и так можно, но хотелось бы все это запаковать в один файл

Для этого и существует управление пакетами. Собирается пакет для нужного дистрибутива и устанавливается штатными средствами.
PM MAIL   Вверх
mrgloom
Дата 5.5.2012, 16:03 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 829
Регистрация: 8.6.2011

Репутация: нет
Всего: нет



пытаюсь вызвать так. кстати так получается вызывать только функции, а как вызывать метод класса?
Код

string call_python_func_str(char* module,char* func_name,PyObject *pArgs)
{
    PyObject *pName, *pModule, *pFunc;
    PyObject *pValue;
    string ret;

    Py_Initialize();
    pName = PyString_FromString(module);

    pModule = PyImport_Import(pName);
    Py_DECREF(pName);

    if (pModule != NULL) 
    {
        pFunc = PyObject_GetAttrString(pModule, func_name);

        if (pFunc && PyCallable_Check(pFunc)) 
        {
            pValue = PyObject_CallObject(pFunc, pArgs);
            Py_DECREF(pArgs);
            if (pValue != NULL) 
            {
                // Set return value
                string temp(PyString_AsString(pValue));
                ret= temp;
                Py_DECREF(pValue);
            }
            else 
            {
                Py_DECREF(pFunc);
                Py_DECREF(pModule);
                PyErr_Print();
                fprintf(stderr,"Call failed\n");
                //return -1;
            }
        }
        else 
        {
            if (PyErr_Occurred())
                PyErr_Print();
            fprintf(stderr, "Cannot find function \"%s\"\n", func_name);
            //return -1;
        }
        Py_XDECREF(pFunc);
        Py_DECREF(pModule);
    }
    else 
    {
        PyErr_Print();
        fprintf(stderr, "Failed to load \"%s\"\n", module);
    }
    Py_Finalize();

    return ret;
}


Это сообщение отредактировал(а) mrgloom - 5.5.2012, 16:22
PM MAIL   Вверх
rsm
Дата 5.5.2012, 16:47 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник Клуба
Сообщений: 999
Регистрация: 16.3.2005

Репутация: нет
Всего: 62



Цитата(mrgloom @  5.5.2012,  18:03 Найти цитируемый пост)
как вызывать метод класса?

Для этого сначала нужно создать класс! © К.О.
Вот прекрасный, очень маленький и очень простой биндинг к ALSA - там и классы, и callback, и даже python egg smile
PM MAIL   Вверх
Страницы: (3) Все [1] 2 3 
Ответ в темуСоздание новой темы Создание опроса
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Python: Общие вопросы | Следующая тема »


 




[ Время генерации скрипта: 0.0873 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.