2014-04-22 3 views
1

나는 this tutorial on Embedding Python on C을 따르고 있지만, Pure Embedding 예제는 저에게 적합하지 않습니다.Python을 C로 예제를 포함 시키면 작동하지 않습니다.

내가 (이 예에서 촬영) 같은 폴더에 있습니다

call.c

#include <Python.h> 

int 
main(int argc, char *argv[]) 
{ 
    PyObject *pName, *pModule, *pDict, *pFunc; 
    PyObject *pArgs, *pValue; 
    int i; 

    if (argc < 3) { 
     fprintf(stderr,"Usage: call pythonfile funcname [args]\n"); 
     return 1; 
    } 

    Py_Initialize(); 
    pName = PyString_FromString(argv[1]); 
    /* Error checking of pName left out */ 

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

    if (pModule != NULL) { 
     pFunc = PyObject_GetAttrString(pModule, argv[2]); 
     /* pFunc is a new reference */ 

     if (pFunc && PyCallable_Check(pFunc)) { 
      pArgs = PyTuple_New(argc - 3); 
      for (i = 0; i < argc - 3; ++i) { 
       pValue = PyInt_FromLong(atoi(argv[i + 3])); 
       if (!pValue) { 
        Py_DECREF(pArgs); 
        Py_DECREF(pModule); 
        fprintf(stderr, "Cannot convert argument\n"); 
        return 1; 
       } 
       /* pValue reference stolen here: */ 
       PyTuple_SetItem(pArgs, i, pValue); 
      } 
      pValue = PyObject_CallObject(pFunc, pArgs); 
      Py_DECREF(pArgs); 
      if (pValue != NULL) { 
       printf("Result of call: %ld\n", PyInt_AsLong(pValue)); 
       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", argv[2]); 
     } 
     Py_XDECREF(pFunc); 
     Py_DECREF(pModule); 
    } 
    else { 
     PyErr_Print(); 
     fprintf(stderr, "Failed to load \"%s\"\n", argv[1]); 
     return 1; 
    } 
    Py_Finalize(); 
    return 0; 
} 

multiply.py

def multiply(a,b): 
    print "Will compute", a, "times", b 
    c = 0 
    for i in range(0, a): 
     c = c + b 
    return c 

내가 컴파일 및 실행 이렇게 :

$ gcc $(python-config --cflags) call.c $(python-config --ldflags) -o call 
call.c: In function ‘main’: 
call.c:6:33: warning: unused variable ‘pDict’ [-Wunused-variable] 
    PyObject *pName, *pModule, *pDict, *pFunc; 
           ^
# This seems OK because it's true that pDict is not used 

$ ./call multiply multiply 3 2 
ImportError: No module named multiply 
Failed to load "multiply" 

multiply 모듈을로드 할 수없는 이유는 무엇입니까? 예제에는 파일 이름이나 경로가 표시되지 않습니다. 경로 문제가 될 수 있습니까?

고마워요. PYTHONPATH 설정

+0

대화식 인터프리터에서 해당 모듈을 가져올 수 있습니까? 'python -c 'import multiply''? python3을 설치했다면 해당 모듈을 가져올 때'SyntaxError'가 나타날 것입니다. – Bakuriu

+0

multiply.py와 같은 폴더에 있다면 예. –

답변

3

시도 :

export PYTHONPATH=`pwd` 
+1

디렉토리를 변경하면이 문제가 발생합니다. 프로그램을 다음과 같이 시작할 수 있습니다 :'PYTHONPATH =. ./call 곱하기 3 2' 그리고'call' 프로그램은 그 환경에서 재정의 된'PYTHONPATH' 변수를받습니다. – Bakuriu