本文整理匯總了Python中contextlib.suppress方法的典型用法代碼示例。如果您正苦於以下問題:Python contextlib.suppress方法的具體用法?Python contextlib.suppress怎麽用?Python contextlib.suppress使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類contextlib
的用法示例。
在下文中一共展示了contextlib.suppress方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: _make_socket
# 需要導入模塊: import contextlib [as 別名]
# 或者: from contextlib import suppress [as 別名]
def _make_socket(iface_name: str, can_fd: bool) -> socket.SocketType:
s = socket.socket(socket.PF_CAN, socket.SOCK_RAW, socket.CAN_RAW)
try:
s.bind((iface_name,))
s.setsockopt(socket.SOL_SOCKET, _SO_TIMESTAMP, 1) # timestamping
if can_fd:
s.setsockopt(socket.SOL_CAN_RAW, socket.CAN_RAW_FD_FRAMES, 1)
s.setblocking(False)
if 0 != s.getsockopt(socket.SOL_SOCKET, socket.SO_ERROR):
raise OSError('Could not configure the socket: getsockopt(SOL_SOCKET, SO_ERROR) != 0')
except BaseException:
with contextlib.suppress(Exception):
s.close()
raise
return s
示例2: test_reloader_live
# 需要導入模塊: import contextlib [as 別名]
# 或者: from contextlib import suppress [as 別名]
def test_reloader_live(runargs, mode):
with TemporaryDirectory() as tmpdir:
filename = os.path.join(tmpdir, "reloader.py")
text = write_app(filename, **runargs)
proc = Popen(argv[mode], cwd=tmpdir, stdout=PIPE, creationflags=flags)
try:
timeout = Timer(5, terminate, [proc])
timeout.start()
# Python apparently keeps using the old source sometimes if
# we don't sleep before rewrite (pycache timestamp problem?)
sleep(1)
line = scanner(proc)
assert text in next(line)
# Edit source code and try again
text = write_app(filename, **runargs)
assert text in next(line)
finally:
timeout.cancel()
terminate(proc)
with suppress(TimeoutExpired):
proc.wait(timeout=3)
示例3: render_voxel
# 需要導入模塊: import contextlib [as 別名]
# 或者: from contextlib import suppress [as 別名]
def render_voxel(self, pred, thresh=0.4,
image_path=os.path.join(cfg.RENDERING.BLENDER_TMP_DIR, 'tmp.png')):
# Cleanup the scene
self.clearModel()
out_f = os.path.join(cfg.RENDERING.BLENDER_TMP_DIR, 'tmp.obj')
occupancy = pred > thresh
vertices, faces = voxel2mesh(occupancy)
with contextlib.suppress(IOError):
os.remove(out_f)
write_obj(out_f, vertices, faces)
# Load the obj
bpy.ops.import_scene.obj(filepath=out_f)
bpy.context.scene.render.filepath = image_path
bpy.ops.render.render(write_still=True) # save straight to file
im = np.array(Image.open(image_path)) # read the image
# Last channel is the alpha channel (transparency)
return im[:, :, :3], im[:, :, 3]
示例4: _shutdown_on_exception
# 需要導入模塊: import contextlib [as 別名]
# 或者: from contextlib import suppress [as 別名]
def _shutdown_on_exception(app: skein.ApplicationClient):
# Ensure SIGINT is not masked to enable kill on C-c.
import signal
signal.signal(signal.SIGINT, signal.default_int_handler)
try:
yield
except (KeyboardInterrupt, SystemExit):
with suppress(SkeinError):
app.shutdown(FinalStatus.KILLED)
logger.error("Application killed on user request")
except Exception:
with suppress(SkeinError):
app.shutdown(FinalStatus.FAILED)
logger.exception("Application shutdown due to an exception")
raise
示例5: _aggregate_events
# 需要導入模塊: import contextlib [as 別名]
# 或者: from contextlib import suppress [as 別名]
def _aggregate_events(
kv: skein.kv.KeyValueStore,
events: Dict[str, Dict[str, str]]
) -> None:
"""
Aggregate events from all dispatched tasks.
The lifecycle of a task consists of three stages:
* init which carries the reserved socket address,
* start with no payload, and
* stop with an optional formatted exception.
"""
# ``ConnectionError`` indicates that the app has finished and
# the AM is down.
queue = kv.events(event_type="PUT")
with suppress(skein.exceptions.ConnectionError), queue:
for evt in queue:
if "/" in evt.key:
task, stage = evt.key.rsplit("/", 1)
events[task][stage] = evt.result.value.decode()
示例6: events
# 需要導入模塊: import contextlib [as 別名]
# 或者: from contextlib import suppress [as 別名]
def events(self, eventsockets):
"""used for external event loops: handle events that occur on one of the sockets of this server"""
# we only react on events on our own server socket.
# all other (client) sockets are owned by their individual threads.
assert self.sock in eventsockets
with contextlib.suppress(socket.timeout): # just continue the loop on a timeout on accept
events = self._selector.select(config.POLLTIMEOUT)
if not events:
return
csock, caddr = self.sock.accept()
if self.shutting_down:
csock.close()
return
if hasattr(csock, "getpeercert"):
log.debug("connected %s - SSL", caddr)
else:
log.debug("connected %s - unencrypted", caddr)
if config.COMMTIMEOUT:
csock.settimeout(config.COMMTIMEOUT)
job = ClientConnectionJob(csock, caddr, self.daemon)
try:
self.pool.process(job)
except NoFreeWorkersError:
job.denyConnection("no free workers, increase server threadpool size")
示例7: close
# 需要導入模塊: import contextlib [as 別名]
# 或者: from contextlib import suppress [as 別名]
def close(self):
if self.housekeeper:
self.housekeeper.stop.set()
self.housekeeper.join()
self.housekeeper = None
if self.sock:
with contextlib.suppress(socket.error, OSError):
sockname = self.sock.getsockname()
with contextlib.suppress(Exception):
self.sock.close()
if type(sockname) is str:
# it was a Unix domain socket, remove it from the filesystem
if os.path.exists(sockname):
os.remove(sockname)
self.sock = None
self.pool.close()
示例8: close
# 需要導入模塊: import contextlib [as 別名]
# 或者: from contextlib import suppress [as 別名]
def close(self):
if self.proxy and self.proxy._pyroConnection is not None:
if self.pyroseq == self.proxy._pyroSeq:
# we're still in sync, it's okay to use the same proxy to close this stream
self.proxy._pyroInvoke("close_stream", [self.streamId], {},
flags=protocol.FLAGS_ONEWAY, objectId=core.DAEMON_NAME)
else:
# The proxy's sequence number has diverged.
# One of the reasons this can happen is because this call is being done from python's GC where
# it decides to gc old iterator objects *during a new call on the proxy*.
# If we use the same proxy and do a call in between, the other call on the proxy will get an out of sync seq and crash!
# We create a temporary second proxy to call close_stream on. This is inefficient, but avoids the problem.
with contextlib.suppress(errors.CommunicationError):
with self.proxy.__copy__() as closingProxy:
closingProxy._pyroInvoke("close_stream", [self.streamId], {},
flags=protocol.FLAGS_ONEWAY, objectId=core.DAEMON_NAME)
self.proxy = None
示例9: bind_unused_port
# 需要導入模塊: import contextlib [as 別名]
# 或者: from contextlib import suppress [as 別名]
def bind_unused_port(sock: socket.socket, host: Union[str, ipaddress.IPv4Address, ipaddress.IPv6Address] = 'localhost') -> int:
"""Bind the socket to a free port and return the port number.
This code is based on the code in the stdlib's test.test_support module."""
if sock.family in (socket.AF_INET, socket.AF_INET6) and sock.type == socket.SOCK_STREAM:
if hasattr(socket, "SO_EXCLUSIVEADDRUSE"):
with contextlib.suppress(socket.error):
sock.setsockopt(socket.SOL_SOCKET, socket.SO_EXCLUSIVEADDRUSE, 1)
if not isinstance(host, str):
host = str(host)
if sock.family == socket.AF_INET:
if host == 'localhost':
sock.bind(('127.0.0.1', 0))
else:
sock.bind((host, 0))
elif sock.family == socket.AF_INET6:
if host == 'localhost':
sock.bind(('::1', 0, 0, 0))
else:
sock.bind((host, 0, 0, 0))
else:
raise CommunicationError("unsupported socket family: " + str(sock.family))
return sock.getsockname()[1]
示例10: testCreateUnboundSockets6
# 需要導入模塊: import contextlib [as 別名]
# 或者: from contextlib import suppress [as 別名]
def testCreateUnboundSockets6(self):
if not has_ipv6:
pytest.skip("no ipv6 capability")
s = socketutil.create_socket(ipv6=True)
assert socket.AF_INET6 == s.family
bs = socketutil.create_bc_socket(ipv6=True)
assert socket.AF_INET6 == bs.family
with contextlib.suppress(socket.error):
host, port, _, _ = s.getsockname()
# can either fail with socket.error or return (host,0)
assert 0 == port
with contextlib.suppress(socket.error):
host, port, _, _ = bs.getsockname()
# can either fail with socket.error or return (host,0)
assert 0 == port
s.close()
bs.close()
示例11: _register_scatter
# 需要導入模塊: import contextlib [as 別名]
# 或者: from contextlib import suppress [as 別名]
def _register_scatter():
"""
Patch `PathCollection` and `scatter` to register their return values.
This registration allows us to distinguish `PathCollection`s created by
`Axes.scatter`, which should use point-like picking, from others, which
should use path-like picking. The former is more common, so we store the
latter instead; this also lets us guess the type better if this module is
imported late.
"""
@functools.wraps(PathCollection.__init__)
def __init__(self, *args, **kwargs):
_nonscatter_pathcollections.add(self)
return __init__.__wrapped__(self, *args, **kwargs)
PathCollection.__init__ = __init__
@functools.wraps(Axes.scatter)
def scatter(*args, **kwargs):
paths = scatter.__wrapped__(*args, **kwargs)
with suppress(KeyError):
_nonscatter_pathcollections.remove(paths)
return paths
Axes.scatter = scatter
示例12: test_cancelled_error_not_captured
# 需要導入模塊: import contextlib [as 別名]
# 或者: from contextlib import suppress [as 別名]
def test_cancelled_error_not_captured(
sentry_init, aiohttp_client, loop, capture_events
):
sentry_init(integrations=[AioHttpIntegration()])
async def hello(request):
raise asyncio.CancelledError()
app = web.Application()
app.router.add_get("/", hello)
events = capture_events()
client = await aiohttp_client(app)
with suppress(ServerDisconnectedError):
# Intended `aiohttp` interaction: server will disconnect if it
# encounters `asyncio.CancelledError`
await client.get("/")
assert not events
示例13: update
# 需要導入模塊: import contextlib [as 別名]
# 或者: from contextlib import suppress [as 別名]
def update(self, data, properties):
updated = self.set_property('location', properties['location'])
updated |= self.set_property('creation_date', data.creation_date)
updated |= self.set_property('bucket_policy', properties['bucket_policy'])
updated |= self.set_property('website_enabled', properties['website_enabled'])
updated |= self.set_property('metrics', properties['metrics'])
with suppress(ClientError):
tags = {t['Key']: t['Value'] for t in data.Tagging().tag_set}
existing_tags = {x.key: x for x in self.tags}
# Check for new tags
for key, value in list(tags.items()):
updated |= self.set_tag(key, value)
# Check for updated or removed tags
for key in list(existing_tags.keys()):
if key not in tags:
updated |= self.delete_tag(key)
return updated
示例14: cls
# 需要導入模塊: import contextlib [as 別名]
# 或者: from contextlib import suppress [as 別名]
def cls(self, target, source=None):
if isinstance(target, str):
target = resolve(target, package=self.target)
if self.source and source is None:
with suppress(ImportError):
source_str = '{mod}.{cls}'.format(
mod=target.__module__.replace('.', self.module_sep),
cls=target.__name__)
source = resolve(source_str, package=self.source)
if not source:
with suppress(AttributeError):
source = getattr(self.source, target.__name__)
elif isinstance(source, str):
source = resolve(source, package=self.source)
if isinstance(target, type):
return PatchClass(target, source)
raise TypeError('Must be a valid class or class name')
示例15: _join_daemon
# 需要導入模塊: import contextlib [as 別名]
# 或者: from contextlib import suppress [as 別名]
def _join_daemon(self):
with contextlib.suppress(IOError):
os.waitpid(self.get_pid(), 0)