Pybind:是否可以告知 Python 有关构造函数参数名称的信息?

4 python constructor spyder anaconda pybind11

在 Pybind 中,可以向 Python 告知函数参数的名称

m.def("add", &add, "A function which adds two numbers",
  py::arg("i"), py::arg("j"));
Run Code Online (Sandbox Code Playgroud)

http://pybind11.readthedocs.io/en/stable/basics.html#keyword-arguments

构造函数有类似的东西吗?Spyder (Anaconda) 已经默认显示函数的输入参数,但对于构​​造函数,“帮助”仅显示:(*args, **kwargs)。

Eve*_*len 5

是的,与成员函数或函数的方式完全相同:)

struct Foo {
    Foo(int x, int y) {}
    void bar(int a, int b) {}
};

PYBIND11_MODULE(cpp_module, m) {
    py::class_<Foo>(m, "Foo")
        .def(py::init<int, int>(), py::arg("x"), py::arg("y"))
        .def("bar", &Foo::bar, py::arg("a"), py::arg("b"));
}
Run Code Online (Sandbox Code Playgroud)

据我所知,使用py::argfor 函数、成员函数或构造函数之间没有真正的区别,它的工作方式是相同的(包括默认值等)。


重载函数(包括构造函数)是一个有趣的例子。由于Python没有类似的重载机制,因此由pybind11处理。help()仍然可以工作,但它会显示类似这样的内容:

__init__(...)
    __init__(*args, **kwargs)
    Overloaded function.

    1. __init__(self: some_cpp.Foo, x: int, y: int) -> None

    2. __init__(self: some_cpp.Foo) -> None
Run Code Online (Sandbox Code Playgroud)

正如您所看到的,__init__它本身需要(*args, **kwargs)并且这将是大多数 IDE 自动完成的内容。解决这个问题的一种方法是使用静态方法作为构造函数,这样你就可以给每个构造函数一个唯一的名称,以便 Python 知道这一点。例如,Foo Foo::from_ints(int x, int y)Foo Foo::from_string(std::string s)