data_reader_writer.rst 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208
  1. Data Reader Writer
  2. ====================
  3. Aims for read or write bytes from different media, You can implement new classes to meet the needs of your personal scenarios
  4. if MinerU have not provide the suitable classes. It is easy to implement new classes, the only one requirement is to inherit from
  5. ``DataReader`` or ``DataWriter``
  6. .. code:: python
  7. class SomeReader(DataReader):
  8. def read(self, path: str) -> bytes:
  9. pass
  10. def read_at(self, path: str, offset: int = 0, limit: int = -1) -> bytes:
  11. pass
  12. class SomeWriter(DataWriter):
  13. def write(self, path: str, data: bytes) -> None:
  14. pass
  15. def write_string(self, path: str, data: str) -> None:
  16. pass
  17. Reader may curious about the difference between :doc:`io` and this section. Those two sections look very similarity at first glance.
  18. :doc:`io` provides fundamental functions, while This section thinks more at application level. Customer can build they own classes to meet
  19. their own applications need which may share same IO function. That is why we have :doc:`io`.
  20. Important Classes
  21. -----------------
  22. .. code:: python
  23. class FileBasedDataReader(DataReader):
  24. def __init__(self, parent_dir: str = ''):
  25. pass
  26. class FileBasedDataWriter(DataWriter):
  27. def __init__(self, parent_dir: str = '') -> None:
  28. pass
  29. Class ``FileBasedDataReader`` initialized with unary param ``parent_dir``, That means that every method ``FileBasedDataReader`` provided will have features as follow.
  30. Features:
  31. #. read content from the absolute path file, ``parent_dir`` will be ignored.
  32. #. read the relative path, file will first join with ``parent_dir``, then read content from the merged path
  33. .. note::
  34. ``FileBasedDataWriter`` shares the same behavior with ``FileBaseDataReader``
  35. .. code:: python
  36. class MultiS3Mixin:
  37. def __init__(self, default_prefix: str, s3_configs: list[S3Config]):
  38. pass
  39. class MultiBucketS3DataReader(DataReader, MultiS3Mixin):
  40. pass
  41. All read-related method that class ``MultiBucketS3DataReader`` provided will have features as follow.
  42. Features:
  43. #. read object with full s3-format path, for example ``s3://test_bucket/test_object``, ``default_prefix`` will be ignored.
  44. #. read object with relative path, file will join ``default_prefix`` and trim the ``bucket_name`` firstly, then read the content. ``bucket_name`` is the first element of the result after split ``default_prefix`` with delimiter ``\``
  45. .. note::
  46. ``MultiBucketS3DataWriter`` shares the same behavior with ``MultiBucketS3DataReader``
  47. .. code:: python
  48. class S3DataReader(MultiBucketS3DataReader):
  49. pass
  50. ``S3DataReader`` is build on top of MultiBucketS3DataReader which only support for bucket. So is ``S3DataWriter``.
  51. Read Examples
  52. ------------
  53. .. code:: python
  54. from magic_pdf.data.data_reader_writer import *
  55. # file based related
  56. file_based_reader1 = FileBasedDataReader('')
  57. ## will read file abc
  58. file_based_reader1.read('abc')
  59. file_based_reader2 = FileBasedDataReader('/tmp')
  60. ## will read /tmp/abc
  61. file_based_reader2.read('abc')
  62. ## will read /var/logs/message.txt
  63. file_based_reader2.read('/var/logs/message.txt')
  64. # multi bucket s3 releated
  65. multi_bucket_s3_reader1 = MultiBucketS3DataReader("test_bucket1/test_prefix", list[S3Config(
  66. bucket_name=test_bucket1, access_key=ak, secret_key=sk, endpoint_url=endpoint_url
  67. ),
  68. S3Config(
  69. bucket_name=test_bucket_2,
  70. access_key=ak_2,
  71. secret_key=sk_2,
  72. endpoint_url=endpoint_url_2,
  73. )])
  74. ## will read s3://test_bucket1/test_prefix/abc
  75. multi_bucket_s3_reader1.read('abc')
  76. ## will read s3://test_bucket1/efg
  77. multi_bucket_s3_reader1.read('s3://test_bucket1/efg')
  78. ## will read s3://test_bucket2/abc
  79. multi_bucket_s3_reader1.read('s3://test_bucket2/abc')
  80. # s3 related
  81. s3_reader1 = S3DataReader(
  82. default_prefix_without_bucket = "test_prefix"
  83. bucket: "test_bucket",
  84. ak: "ak",
  85. sk: "sk",
  86. endpoint_url: "localhost"
  87. )
  88. ## will read s3://test_bucket/test_prefix/abc
  89. s3_reader1.read('abc')
  90. ## will read s3://test_bucket/efg
  91. s3_reader1.read('s3://test_bucket/efg')
  92. Write Examples
  93. ---------------
  94. .. code:: python
  95. from magic_pdf.data.data_reader_writer import *
  96. # file based related
  97. file_based_writer1 = FileBasedDataWriter('')
  98. ## will write 123 to abc
  99. file_based_writer1.write('abc', '123'.encode())
  100. ## will write 123 to abc
  101. file_based_writer1.write_string('abc', '123')
  102. file_based_writer2 = FileBasedDataWriter('/tmp')
  103. ## will write 123 to /tmp/abc
  104. file_based_writer2.write_string('abc', '123')
  105. ## will write 123 to /var/logs/message.txt
  106. file_based_writer2.write_string('/var/logs/message.txt', '123')
  107. # multi bucket s3 releated
  108. multi_bucket_s3_writer1 = MultiBucketS3DataWriter("test_bucket1/test_prefix", list[S3Config(
  109. bucket_name=test_bucket1, access_key=ak, secret_key=sk, endpoint_url=endpoint_url
  110. ),
  111. S3Config(
  112. bucket_name=test_bucket_2,
  113. access_key=ak_2,
  114. secret_key=sk_2,
  115. endpoint_url=endpoint_url_2,
  116. )])
  117. ## will write 123 to s3://test_bucket1/test_prefix/abc
  118. multi_bucket_s3_writer1.write_string('abc', '123')
  119. ## will write 123 to s3://test_bucket1/test_prefix/abc
  120. multi_bucket_s3_writer1.write('abc', '123'.encode())
  121. ## will write 123 to s3://test_bucket1/efg
  122. multi_bucket_s3_writer1.write('s3://test_bucket1/efg', '123'.encode())
  123. ## will write 123 to s3://test_bucket2/abc
  124. multi_bucket_s3_writer1.write('s3://test_bucket2/abc', '123'.encode())
  125. # s3 related
  126. s3_writer1 = S3DataWriter(
  127. default_prefix_without_bucket = "test_prefix"
  128. bucket: "test_bucket",
  129. ak: "ak",
  130. sk: "sk",
  131. endpoint_url: "localhost"
  132. )
  133. ## will write 123 to s3://test_bucket/test_prefix/abc
  134. s3_writer1.write('abc', '123'.encode())
  135. ## will write 123 to s3://test_bucket/test_prefix/abc
  136. s3_writer1.write_string('abc', '123')
  137. ## will write 123 to s3://test_bucket/efg
  138. s3_writer1.write('s3://test_bucket/efg', '123'.encode())
  139. Check :doc:`../../api/data_reader_writer` for more details