4

Python で ctypes を使用して関数を正常に呼び出すことができます。抽出したいデータの構造で満たされたバッファができました。これに最適な戦略は何ですか?他に投稿すべきことはありますか?

関数:

class list():
    def __init__(self):
        #[...]

    def getdirentries(self, path):
        self.load_c()
        self.fd = os.open(path, os.O_RDONLY)
        self.statinfo = os.fstat(self.fd)
        self.buffer = ctypes.create_string_buffer(self.statinfo.st_size)
        nbytes = self.statinfo.st_size

        transferred_bytes = self.libc.getdirentries(
                        self.fd,
                        ctypes.byref(self.buffer),
                        nbytes,
                        ctypes.byref(self.basep)  )

    #[...]

構造:

class dirent(ctypes.Structure):
    _fields_ = [ ("d_fileno", ctypes.c_uint32), # /* file number of entry */
                 ("d_reclen", ctypes.c_uint16), # /* length of this record */
                 ("d_type", ctypes.c_uint8), # /* file type */
                 ("d_namlen", ctypes.c_uint8), # /* length of string in d_name */
                 ("d_name", ctypes.c_char * (MAXNAMELEN + 1) ) ]

一部の出力:
転送されたバイト数: 156バッファーの
サイズ: 272
バッファー:<ctypes.c_char_Array_272 object at 0x8c3f0>

4

1 に答える 1

0

statinfo を呼び出す代わりに os.stat() を使用し、getdirentries を呼び出す代わりに os.path.walk() を使用しているのはなぜでしょうか?

通常、C との間で受け渡ししたいデータのバッファーがある場合は、構造体モジュールの pack および unpack メソッドを使用してこれを行います。

于 2009-10-16T16:13:48.773 に答える