mmap
— Memory-mapped file support¶
Availability: not WASI.
This module does not work or is not available on WebAssembly. See WebAssembly platforms for more information.
메모리 맵 파일 객체는 동시에 bytearray
와 파일 객체처럼 작동합니다. bytearray
를 기대하는 대부분 장소에서 mmap 객체를 사용할 수 있습니다. 예를 들어, re
모듈을 사용하여 메모리 맵 파일을 검색할 수 있습니다. obj[index] = 97
를 사용해서 한 바이트를 변경하거나, 슬라이스에 대입하여 서브 시퀀스를 변경할 수도 있습니다: obj[i1:i2] = b'...'
. 또한 현재 파일 위치에서 시작하여 데이터를 읽고 쓸 수 있고, 다른 위치로 파일을 seek()
할 수 있습니다.
A memory-mapped file is created by the mmap
constructor, which is
different on Unix and on Windows. In either case you must provide a file
descriptor for a file opened for update. If you wish to map an existing Python
file object, use its fileno()
method to obtain the correct value for the
fileno parameter. Otherwise, you can open the file using the
os.open()
function, which returns a file descriptor directly (the file
still needs to be closed when done).
참고
쓰기 가능하고 버퍼링 되는 파일에 대한 메모리 맵을 만들려면, 먼저 파일을 flush()
해야 합니다. 버퍼에 대한 지역 변경 사항이 실제로 매핑에 반영되게 하는 데 필요합니다.
유닉스와 윈도우 버전의 생성자 모두에서, access는 선택적 키워드 매개 변수로 지정될 수 있습니다. access는 ACCESS_READ
, ACCESS_WRITE
또는 ACCESS_COPY
중 하나의 값을 받아, 읽기 전용, 동시 기록(write-through) 또는 쓸 때 복사(copy-on-write) 메모리를 각각 지정하거나, ACCESS_DEFAULT
를 사용하여 prot로 위임합니다. access는 유닉스와 윈도우에서 모두 사용할 수 있습니다. access를 지정하지 않으면, 윈도우 mmap은 동시 기록(write-through) 매핑을 반환합니다. 세 가지 액세스 유형 모두에서 초기 메모리값은 지정된 파일에서 가져옵니다. ACCESS_READ
메모리 맵에 대입하면 TypeError
예외가 발생합니다. ACCESS_WRITE
메모리 맵에 대입하면 메모리와 하부 파일에 모두 영향을 줍니다. ACCESS_COPY
메모리 맵에 대입하면 메모리에는 영향을 미치지만, 하부 파일은 변경되지 않습니다.
버전 3.7에서 변경: ACCESS_DEFAULT
상수가 추가되었습니다.
익명 메모리를 매핑하려면, length와 함께 -1을 fileno로 전달해야 합니다.
- class mmap.mmap(fileno, length, tagname=None, access=ACCESS_DEFAULT, offset=0)¶
(윈도우 버전) 파일 핸들 fileno로 지정된 파일의 length 바이트를 매핑하고, mmap 객체를 만듭니다. length가 파일의 현재 크기보다 크면, 파일은 length 바이트를 포함하도록 확장됩니다. length가
0
이면, 맵의 최대 길이는 파일의 현재 길이입니다. 단, 파일이 비어 있으면 윈도우에서 예외가 발생합니다 (윈도우에는 빈 매핑을 만들 수 없습니다).tagname, if specified and not
None
, is a string giving a tag name for the mapping. Windows allows you to have many different mappings against the same file. If you specify the name of an existing tag, that tag is opened, otherwise a new tag of this name is created. If this parameter is omitted orNone
, the mapping is created without a name. Avoiding the use of the tagname parameter will assist in keeping your code portable between Unix and Windows.offset은 음이 아닌 정수 오프셋으로 지정할 수 있습니다. mmap 참조는 파일 시작 부분으로부터의 오프셋에 상대적입니다. offset의 기본값은 0입니다. offset은
ALLOCATIONGRANULARITY
의 배수여야 합니다.인자
fileno
,length
,access
,offset
로 감사 이벤트(auditing event)mmap.__new__
를 발생시킵니다.
- class mmap.mmap(fileno, length, flags=MAP_SHARED, prot=PROT_WRITE | PROT_READ, access=ACCESS_DEFAULT, offset=0, *, trackfd=True)
(유닉스 버전) 파일 기술자 fileno로 지정된 파일의 length 바이트를 매핑하고, mmap 객체를 반환합니다. length가
0
이면, 맵의 최대 길이는mmap
가 호출될 때 파일의 현재 길이입니다.flags specifies the nature of the mapping.
MAP_PRIVATE
creates a private copy-on-write mapping, so changes to the contents of the mmap object will be private to this process, andMAP_SHARED
creates a mapping that’s shared with all other processes mapping the same areas of the file. The default value isMAP_SHARED
. Some systems have additional possible flags with the full list specified in MAP_* constants.prot가 지정되면 원하는 메모리 보호를 제공합니다; 가장 유용한 두 값은 페이지를 읽거나 쓰도록 지정할 수 있는
PROT_READ
와PROT_WRITE
입니다. prot의 기본값은PROT_READ | PROT_WRITE
입니다.access는 선택적 키워드 매개 변수로 flags 와 prot 대신 지정 될 수 있습니다. flags, prot 와 access를 모두 지정하는 것은 에러입니다. 이 매개 변수를 사용하는 방법에 대한 정보는 위의 access 설명을 참조하십시오.
offset은 음이 아닌 정수 오프셋으로 지정할 수 있습니다. mmap 참조는 파일 시작 부분으로부터의 오프셋에 상대적입니다. offset의 기본값은 0입니다. offset은 유닉스 시스템에서
PAGESIZE
와 같은ALLOCATIONGRANULARITY
의 배수여야 합니다.If trackfd is
False
, the file descriptor specified by fileno will not be duplicated, and the resultingmmap
object will not be associated with the map’s underlying file. This means that thesize()
andresize()
methods will fail. This mode is useful to limit the number of open file descriptors.To ensure validity of the created memory mapping the file specified by the descriptor fileno is internally automatically synchronized with the physical backing store on macOS.
버전 3.13에서 변경: The trackfd parameter was added.
이 예제는
mmap
을 사용하는 간단한 방법을 보여줍니다:import mmap # write a simple example file with open("hello.txt", "wb") as f: f.write(b"Hello Python!\n") with open("hello.txt", "r+b") as f: # memory-map the file, size 0 means whole file mm = mmap.mmap(f.fileno(), 0) # read content via standard file methods print(mm.readline()) # prints b"Hello Python!\n" # read content via slice notation print(mm[:5]) # prints b"Hello" # update content using slice notation; # note that new content must have same size mm[6:] = b" world!\n" # ... and read again using standard file methods mm.seek(0) print(mm.readline()) # prints b"Hello world!\n" # close the map mm.close()
mmap
은with
문에서 컨텍스트 관리자로 사용할 수도 있습니다:import mmap with mmap.mmap(-1, 13) as mm: mm.write(b"Hello world!")
Added in version 3.2: 컨텍스트 관리자 지원.
다음 예제는 익명 맵을 만들고 부모와 자식 프로세스 간에 데이터를 교환하는 방법을 보여줍니다:
import mmap import os mm = mmap.mmap(-1, 13) mm.write(b"Hello world!") pid = os.fork() if pid == 0: # In a child process mm.seek(0) print(mm.readline()) mm.close()
인자
fileno
,length
,access
,offset
로 감사 이벤트(auditing event)mmap.__new__
를 발생시킵니다.메모리 맵 파일 객체는 다음 메서드를 지원합니다:
- close()¶
mmap를 닫습니다. 이후에 객체의 다른 메서드를 호출하면 ValueError 예외가 발생합니다. 열려있는 파일을 닫지 않습니다.
- closed¶
파일이 닫혔으면
True
입니다.Added in version 3.2.
- find(sub[, start[, end]])¶
서브 시퀀스 sub가 발견되는 객체에서 가장 낮은 인덱스를 반환합니다. sub는 [start, end] 범위에 포함되어야 합니다. 선택적 인자 start 와 end는 슬라이스 표기법처럼 해석됩니다. 실패하면
-1
를 반환합니다.버전 3.5에서 변경: 이제 쓰기 가능한 바이트열류 객체를 받아들입니다.
- flush([offset[, size]])¶
파일의 메모리 내 복사본에 대한 변경 사항을 디스크로 플러시 합니다. 이 호출을 사용하지 않으면, 객체가 파괴되기 전에 변경 내용이 기록된다고 보장할 수 없습니다. offset과 size가 지정되면, 지정된 바이트 범위의 변경 사항만 디스크로 플러시 됩니다; 그렇지 않으면, 매핑의 전체 범위가 플러시 됩니다. offset은
PAGESIZE
나ALLOCATIONGRANULARITY
의 배수여야 합니다.성공을 나타내기 위해
None
이 반환됩니다. 호출이 실패하면 예외가 발생합니다.버전 3.8에서 변경: 이전에는, 성공 시 0이 아닌 값이 반환되었습니다; 윈도우에서 에러 시 0이 반환되었습니다. 성공 시 0 값이 반환되었습니다; 유닉스에서 에러 시 예외가 발생했습니다.
- madvise(option[, start[, length]])¶
start에서 시작하고 length 바이트만큼 확장하는 메모리 영역에 대해 커널에 조언 option을 보냅니다. option은 시스템에서 사용할 수 있는 MADV_* 상수 중 하나여야 합니다. start와 length가 생략되면, 전체 매핑으로 확장됩니다. 일부 시스템(리눅스 포함)에서, start는
PAGESIZE
의 배수여야 합니다.가용성:
madvise()
시스템 호출이 있는 시스템.Added in version 3.8.
- move(dest, src, count)¶
오프셋 src에서 시작하는 count 바이트를 대상 인덱스 dest로 복사합니다. mmap이
ACCESS_READ
로 만들어졌으면, move를 호출하면TypeError
예외가 발생합니다.
- read([n])¶
현재의 파일 위치로부터 최대 n 바이트를 포함하는
bytes
를 반환합니다. 인자가 생략되거나None
이거나 음수면, 현재 파일 위치에서 매핑의 끝까지 모든 바이트를 반환합니다. 파일 위치는 반환된 바이트의 뒤를 가리키도록 갱신됩니다.버전 3.3에서 변경: 인자는 생략되거나
None
일 수 있습니다.
- read_byte()¶
현재 파일 위치의 한 바이트를 정수로 반환하고, 파일 위치를 1 증가시킵니다.
- readline()¶
현재 파일 위치에서 시작하여 다음 줄 바꿈까지 한 줄을 반환합니다. 반환된 바이트 뒤를 가리키도록 파일 위치가 갱신됩니다.
- resize(newsize)¶
Resizes the map and the underlying file, if any.
Resizing a map created with access of
ACCESS_READ
orACCESS_COPY
, will raise aTypeError
exception. Resizing a map created with with trackfd set toFalse
, will raise aValueError
exception.On Windows: Resizing the map will raise an
OSError
if there are other maps against the same named file. Resizing an anonymous map (ie against the pagefile) will silently create a new map with the original data copied over up to the length of the new size.버전 3.11에서 변경: Correctly fails if attempting to resize when another map is held Allows resize against an anonymous map on Windows
- rfind(sub[, start[, end]])¶
서브 시퀀스 sub가 발견되는 객체에서 가장 높은 인덱스를 반환합니다. sub는 [start, end] 범위에 포함되어야 합니다. 선택적 인자 start 와 end는 슬라이스 표기법처럼 해석됩니다. 실패하면
-1
를 반환합니다.버전 3.5에서 변경: 이제 쓰기 가능한 바이트열류 객체를 받아들입니다.
- seek(pos[, whence])¶
파일의 현재 위치를 설정합니다. whence 인자는 선택적이며 기본값은
os.SEEK_SET
또는0
(절대 파일 위치)입니다; 다른 값은os.SEEK_CUR
또는1
(현재 위치를 기준으로 seek)과os.SEEK_END
또는2
(파일의 끝을 기준으로 seek)입니다.버전 3.13에서 변경: Return the new absolute position instead of
None
.
- seekable()¶
Return whether the file supports seeking, and the return value is always
True
.Added in version 3.13.
- size()¶
파일의 길이를 반환합니다. 메모리 매핑된 영역의 크기보다 클 수 있습니다.
- tell()¶
파일 포인터의 현재 위치를 반환합니다.
- write(bytes)¶
bytes의 바이트를 파일 포인터의 현재 위치에 있는 메모리에 기록하고 기록된 바이트 수를 반환합니다 (쓰기가 실패하면
ValueError
가 발생하기 때문에 결코len(bytes)
보다 작지 않습니다). 파일 위치는 기록된 바이트 뒤를 가리 키도록 갱신됩니다. mmap이ACCESS_READ
로 만들어졌으면, 기록할 때TypeError
예외가 발생합니다.버전 3.5에서 변경: 이제 쓰기 가능한 바이트열류 객체를 받아들입니다.
버전 3.6에서 변경: 이제 기록한 바이트 수가 반환됩니다.
MADV_* 상수¶
- mmap.MADV_NORMAL¶
- mmap.MADV_RANDOM¶
- mmap.MADV_SEQUENTIAL¶
- mmap.MADV_WILLNEED¶
- mmap.MADV_DONTNEED¶
- mmap.MADV_REMOVE¶
- mmap.MADV_DONTFORK¶
- mmap.MADV_DOFORK¶
- mmap.MADV_HWPOISON¶
- mmap.MADV_MERGEABLE¶
- mmap.MADV_UNMERGEABLE¶
- mmap.MADV_SOFT_OFFLINE¶
- mmap.MADV_HUGEPAGE¶
- mmap.MADV_NOHUGEPAGE¶
- mmap.MADV_DONTDUMP¶
- mmap.MADV_DODUMP¶
- mmap.MADV_FREE¶
- mmap.MADV_NOSYNC¶
- mmap.MADV_AUTOSYNC¶
- mmap.MADV_NOCORE¶
- mmap.MADV_CORE¶
- mmap.MADV_PROTECT¶
- mmap.MADV_FREE_REUSABLE¶
- mmap.MADV_FREE_REUSE¶
이 옵션은
mmap.madvise()
로 전달될 수 있습니다. 모든 시스템에서 모든 옵션이 제공되는 것은 아닙니다.가용성: madvise() 시스템 호출이 있는 시스템.
Added in version 3.8.
MAP_* Constants¶
- mmap.MAP_SHARED¶
- mmap.MAP_PRIVATE¶
- mmap.MAP_32BIT¶
- mmap.MAP_ALIGNED_SUPER¶
- mmap.MAP_ANON¶
- mmap.MAP_ANONYMOUS¶
- mmap.MAP_CONCEAL¶
- mmap.MAP_DENYWRITE¶
- mmap.MAP_EXECUTABLE¶
- mmap.MAP_HASSEMAPHORE¶
- mmap.MAP_JIT¶
- mmap.MAP_NOCACHE¶
- mmap.MAP_NOEXTEND¶
- mmap.MAP_NORESERVE¶
- mmap.MAP_POPULATE¶
- mmap.MAP_RESILIENT_CODESIGN¶
- mmap.MAP_RESILIENT_MEDIA¶
- mmap.MAP_STACK¶
- mmap.MAP_TPRO¶
- mmap.MAP_TRANSLATED_ALLOW_EXECUTE¶
- mmap.MAP_UNIX03¶
These are the various flags that can be passed to
mmap.mmap()
.MAP_ALIGNED_SUPER
is only available at FreeBSD andMAP_CONCEAL
is only available at OpenBSD. Note that some options might not be present on some systems.버전 3.10에서 변경: Added
MAP_POPULATE
constant.Added in version 3.11: Added
MAP_STACK
constant.Added in version 3.12: Added
MAP_ALIGNED_SUPER
andMAP_CONCEAL
constants.Added in version 3.13: Added
MAP_32BIT
,MAP_HASSEMAPHORE
,MAP_JIT
,MAP_NOCACHE
,MAP_NOEXTEND
,MAP_NORESERVE
,MAP_RESILIENT_CODESIGN
,MAP_RESILIENT_MEDIA
,MAP_TPRO
,MAP_TRANSLATED_ALLOW_EXECUTE
, andMAP_UNIX03
constants.