當前位置: 首頁>>代碼示例>>Python>>正文


Python os.read方法代碼示例

本文整理匯總了Python中os.read方法的典型用法代碼示例。如果您正苦於以下問題:Python os.read方法的具體用法?Python os.read怎麽用?Python os.read使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在os的用法示例。


在下文中一共展示了os.read方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: _get

# 需要導入模塊: import os [as 別名]
# 或者: from os import read [as 別名]
def _get(self):
        if not self._getMode:
            return
        buf = os.read(self._rt, _MAXLINE).decode()
        if not buf:
            raise CosimulationError(_error.SimulationEnd)
        e = buf.split()
        for i in range(1, len(e), 2):
            s, v = self._toSigDict[e[i]], e[i + 1]
            if v in 'zZ':
                next = None
            elif v in 'xX':
                next = s._init
            else:
                try:
                    next = int(v, 16)
                    if s._nrbits and s._min is not None and s._min < 0:
                        if next >= (1 << (s._nrbits - 1)):
                            next |= (-1 << s._nrbits)
                except ValueError:
                    next = intbv(0)
            s.next = next

        self._getMode = 0 
開發者ID:myhdl,項目名稱:myhdl,代碼行數:26,代碼來源:_Cosimulation.py

示例2: copyfileobj

# 需要導入模塊: import os [as 別名]
# 或者: from os import read [as 別名]
def copyfileobj(src, dst, length=None):
    """Copy length bytes from fileobj src to fileobj dst.
       If length is None, copy the entire content.
    """
    if length == 0:
        return
    if length is None:
        shutil.copyfileobj(src, dst)
        return

    BUFSIZE = 16 * 1024
    blocks, remainder = divmod(length, BUFSIZE)
    for b in range(blocks):
        buf = src.read(BUFSIZE)
        if len(buf) < BUFSIZE:
            raise IOError("end of file reached")
        dst.write(buf)

    if remainder != 0:
        buf = src.read(remainder)
        if len(buf) < remainder:
            raise IOError("end of file reached")
        dst.write(buf)
    return 
開發者ID:war-and-code,項目名稱:jawfish,代碼行數:26,代碼來源:tarfile.py

示例3: read

# 需要導入模塊: import os [as 別名]
# 或者: from os import read [as 別名]
def read(self, size=None):
        """Return the next size number of bytes from the stream.
           If size is not defined, return all bytes of the stream
           up to EOF.
        """
        if size is None:
            t = []
            while True:
                buf = self._read(self.bufsize)
                if not buf:
                    break
                t.append(buf)
            buf = "".join(t)
        else:
            buf = self._read(size)
        self.pos += len(buf)
        return buf 
開發者ID:war-and-code,項目名稱:jawfish,代碼行數:19,代碼來源:tarfile.py

示例4: fromtarfile

# 需要導入模塊: import os [as 別名]
# 或者: from os import read [as 別名]
def fromtarfile(cls, tarfile):
        """Return the next TarInfo object from TarFile object
           tarfile.
        """
        buf = tarfile.fileobj.read(BLOCKSIZE)
        obj = cls.frombuf(buf, tarfile.encoding, tarfile.errors)
        obj.offset = tarfile.fileobj.tell() - BLOCKSIZE
        return obj._proc_member(tarfile)

    #--------------------------------------------------------------------------
    # The following are methods that are called depending on the type of a
    # member. The entry point is _proc_member() which can be overridden in a
    # subclass to add custom _proc_*() methods. A _proc_*() method MUST
    # implement the following
    # operations:
    # 1. Set self.offset_data to the position where the data blocks begin,
    #    if there is data that follows.
    # 2. Set tarfile.offset to the position where the next member's header will
    #    begin.
    # 3. Return self or another valid TarInfo object. 
開發者ID:war-and-code,項目名稱:jawfish,代碼行數:22,代碼來源:tarfile.py

示例5: addfile

# 需要導入模塊: import os [as 別名]
# 或者: from os import read [as 別名]
def addfile(self, tarinfo, fileobj=None):
        """Add the TarInfo object `tarinfo' to the archive. If `fileobj' is
           given, tarinfo.size bytes are read from it and added to the archive.
           You can create TarInfo objects using gettarinfo().
           On Windows platforms, `fileobj' should always be opened with mode
           'rb' to avoid irritation about the file size.
        """
        self._check("aw")

        tarinfo = copy.copy(tarinfo)

        buf = tarinfo.tobuf(self.format, self.encoding, self.errors)
        self.fileobj.write(buf)
        self.offset += len(buf)

        # If there's data to follow, append it.
        if fileobj is not None:
            copyfileobj(fileobj, self.fileobj, tarinfo.size)
            blocks, remainder = divmod(tarinfo.size, BLOCKSIZE)
            if remainder > 0:
                self.fileobj.write(NUL * (BLOCKSIZE - remainder))
                blocks += 1
            self.offset += blocks * BLOCKSIZE

        self.members.append(tarinfo) 
開發者ID:war-and-code,項目名稱:jawfish,代碼行數:27,代碼來源:tarfile.py

示例6: __next__

# 需要導入模塊: import os [as 別名]
# 或者: from os import read [as 別名]
def __next__(self):
        """Return the next item using TarFile's next() method.
           When all members have been read, set TarFile as _loaded.
        """
        # Fix for SF #1100429: Under rare circumstances it can
        # happen that getmembers() is called during iteration,
        # which will cause TarIter to stop prematurely.

        if self.index == 0 and self.tarfile.firstmember is not None:
            tarinfo = self.tarfile.next()
        elif self.index < len(self.tarfile.members):
            tarinfo = self.tarfile.members[self.index]
        elif not self.tarfile._loaded:
            tarinfo = self.tarfile.next()
            if not tarinfo:
                self.tarfile._loaded = True
                raise StopIteration
        else:
            raise StopIteration
        self.index += 1
        return tarinfo

#--------------------
# exported functions
#-------------------- 
開發者ID:war-and-code,項目名稱:jawfish,代碼行數:27,代碼來源:tarfile.py

示例7: read_from_fd

# 需要導入模塊: import os [as 別名]
# 或者: from os import read [as 別名]
def read_from_fd(self):
        try:
            chunk = os.read(self.fd, self.read_chunk_size)
        except (IOError, OSError) as e:
            if errno_from_exception(e) in _ERRNO_WOULDBLOCK:
                return None
            elif errno_from_exception(e) == errno.EBADF:
                # If the writing half of a pipe is closed, select will
                # report it as readable but reads will fail with EBADF.
                self.close(exc_info=True)
                return None
            else:
                raise
        if not chunk:
            self.close()
            return None
        return chunk 
開發者ID:tao12345666333,項目名稱:tornado-zh,代碼行數:19,代碼來源:iostream.py

示例8: test_dupfile

# 需要導入模塊: import os [as 別名]
# 或者: from os import read [as 別名]
def test_dupfile(tmpfile):
    flist = []
    for i in range(5):
        nf = py.io.dupfile(tmpfile, encoding="utf-8")
        assert nf != tmpfile
        assert nf.fileno() != tmpfile.fileno()
        assert nf not in flist
        print_(i, end="", file=nf)
        flist.append(nf)
    for i in range(5):
        f = flist[i]
        f.close()
    tmpfile.seek(0)
    s = tmpfile.read()
    assert "01234" in repr(s)
    tmpfile.close() 
開發者ID:pytest-dev,項目名稱:py,代碼行數:18,代碼來源:test_capture.py

示例9: init_faulthandler

# 需要導入模塊: import os [as 別名]
# 或者: from os import read [as 別名]
def init_faulthandler(self):
        """Handle a segfault from a previous run and set up faulthandler."""
        logname = os.path.join(standarddir.data(), 'crash.log')
        try:
            # First check if an old logfile exists.
            if os.path.exists(logname):
                with open(logname, 'r', encoding='ascii') as f:
                    self._crash_log_data = f.read()
                os.remove(logname)
                self._init_crashlogfile()
            else:
                # There's no log file, so we can use this to display crashes to
                # the user on the next start.
                self._init_crashlogfile()
        except OSError:
            log.init.exception("Error while handling crash log file!")
            self._init_crashlogfile() 
開發者ID:qutebrowser,項目名稱:qutebrowser,代碼行數:19,代碼來源:crashsignal.py

示例10: handle_signal_wakeup

# 需要導入模塊: import os [as 別名]
# 或者: from os import read [as 別名]
def handle_signal_wakeup(self):
        """Handle a newly arrived signal.

        This gets called via self._notifier when there's a signal.

        Python will get control here, so the signal will get handled.
        """
        assert self._notifier is not None
        log.destroy.debug("Handling signal wakeup!")
        self._notifier.setEnabled(False)
        read_fd = self._notifier.socket()
        try:
            os.read(int(read_fd), 1)
        except OSError:
            log.destroy.exception("Failed to read wakeup fd.")
        self._notifier.setEnabled(True) 
開發者ID:qutebrowser,項目名稱:qutebrowser,代碼行數:18,代碼來源:crashsignal.py

示例11: packet_reader_mac

# 需要導入模塊: import os [as 別名]
# 或者: from os import read [as 別名]
def packet_reader_mac(self, tunnel, first_read, serverorclient):
		packet = os.read(tunnel, 4096)
		if first_read and not serverorclient:
			packet = packet[4:]
		return packet

	# for Linux and other unices
	# Windows is handled from the communication() unfortunately 
開發者ID:earthquake,項目名稱:XFLTReaT,代碼行數:10,代碼來源:Stateless_module.py

示例12: packet_reader_default

# 需要導入模塊: import os [as 別名]
# 或者: from os import read [as 別名]
def packet_reader_default(self, tunnel, first_read, serverorclient):
		packet = os.read(tunnel, 4096)
		return packet

	# function to transform packets back and forth.
	# encryption, encodings anything that should be done on the packet and 
	# should be easily variable based on the config 
開發者ID:earthquake,項目名稱:XFLTReaT,代碼行數:9,代碼來源:Stateless_module.py

示例13: post_authentication_client

# 需要導入模塊: import os [as 別名]
# 或者: from os import read [as 別名]
def post_authentication_client(self, control_message, additional_data):
		self.authenticated = True

		return

	# server side
	# if the client was initiated (first step was not skipped), then set
	# the authenticated flag to True, add to packetselector and allow access
	# the read only pipe (packets selected for the client) 
開發者ID:earthquake,項目名稱:XFLTReaT,代碼行數:11,代碼來源:Stateless_module.py

示例14: packet_reader_default

# 需要導入模塊: import os [as 別名]
# 或者: from os import read [as 別名]
def packet_reader_default(self, tunnel, first_read, serverorclient):
		packet = os.read(tunnel, 4096)
		return packet

	# encryption, encodings anything that should be done on the packet and 
	# should be easily variable based on the config 
開發者ID:earthquake,項目名稱:XFLTReaT,代碼行數:8,代碼來源:Stateful_module.py

示例15: delete_client

# 需要導入模塊: import os [as 別名]
# 或者: from os import read [as 別名]
def delete_client(self, client):
		if client in self.clients:

			if self.os_type == common.OS_WINDOWS:
				import win32file

				try:
					win32file.CloseHandle(client.get_pipe_r())
					win32file.CloseHandle(client.get_pipe_w())
				except Exception as e:
					common.internal_print("Remove authenticated client: CloseHandle exception: {0}".format(e), -1)
			else:
				try:
					client.get_pipe_r_fd().close()
					client.get_pipe_w_fd().close()
				except Exception as e:
					common.internal_print("Remove authenticated client: os.close exception: {0}".format(e), -1)

			client.call_stopfp()
			self.clients.remove(client)

		return

	# This function should run from the point when the framework was started.
	# It runs as an infinite loop to read the packets off the tunnel.
	# When an IPv4 packet was found that will be selected and checked whether
	# it addresses a client in the client list. If a client was found, then the
	# packet will be written on that pipe. 
開發者ID:earthquake,項目名稱:XFLTReaT,代碼行數:30,代碼來源:packetselector.py


注:本文中的os.read方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。