本文整理匯總了Python中plistlib.FMT_BINARY屬性的典型用法代碼示例。如果您正苦於以下問題:Python plistlib.FMT_BINARY屬性的具體用法?Python plistlib.FMT_BINARY怎麽用?Python plistlib.FMT_BINARY使用的例子?那麽, 這裏精選的屬性代碼示例或許可以為您提供幫助。您也可以進一步了解該屬性所在類plistlib
的用法示例。
在下文中一共展示了plistlib.FMT_BINARY屬性的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: test_tuple_members
# 需要導入模塊: import plistlib [as 別名]
# 或者: from plistlib import FMT_BINARY [as 別名]
def test_tuple_members(self):
pl = {
'first': (1, 2),
'second': (1, 2),
'third': (3, 4),
}
for fmt in ALL_FORMATS:
with self.subTest(fmt=fmt):
data = plistlib.dumps(pl, fmt=fmt)
pl2 = plistlib.loads(data)
self.assertEqual(pl2, {
'first': [1, 2],
'second': [1, 2],
'third': [3, 4],
})
if fmt != plistlib.FMT_BINARY:
self.assertIsNot(pl2['first'], pl2['second'])
示例2: test_cycles
# 需要導入模塊: import plistlib [as 別名]
# 或者: from plistlib import FMT_BINARY [as 別名]
def test_cycles(self):
# recursive list
a = []
a.append(a)
b = plistlib.loads(plistlib.dumps(a, fmt=plistlib.FMT_BINARY))
self.assertIs(b[0], b)
# recursive tuple
a = ([],)
a[0].append(a)
b = plistlib.loads(plistlib.dumps(a, fmt=plistlib.FMT_BINARY))
self.assertIs(b[0][0], b)
# recursive dict
a = {}
a['x'] = a
b = plistlib.loads(plistlib.dumps(a, fmt=plistlib.FMT_BINARY))
self.assertIs(b['x'], b)
示例3: _send_plist
# 需要導入模塊: import plistlib [as 別名]
# 或者: from plistlib import FMT_BINARY [as 別名]
def _send_plist(self, step, **kwargs):
plist = dict((str(k), v) for k, v in kwargs.items())
headers = copy(_AIRPLAY_HEADERS)
headers["Content-Type"] = "application/x-apple-binary-plist"
# TODO: For some reason pylint does not find FMT_BINARY, why?
# pylint: disable=no-member
resp, code = await self.http.post_data(
"pair-setup-pin", data=plistlib.dumps(plist, fmt=plistlib.FMT_BINARY)
)
if code != 200:
raise AuthenticationError("{0} failed with code {1}".format(step, code))
return resp
# pylint: disable=too-few-public-methods
示例4: write_plist_to_file
# 需要導入模塊: import plistlib [as 別名]
# 或者: from plistlib import FMT_BINARY [as 別名]
def write_plist_to_file(deserialised_plist, output_path):
#Using plistLib to write plist
out_file = None
try:
print('Writing out .. ' + output_path)
out_file = open(output_path, 'wb')
try:
plistlib.dump(deserialised_plist, out_file, fmt=plistlib.FMT_BINARY)
out_file.close()
return True
except (TypeError, OverflowError, OSError) as ex:
out_file.close()
print('Had an exception (error)')
traceback.print_exc()
except OSError as ex:
print('Error opening file for writing: Error={} Path={}'.format(output_path, str(ex)))
# Try using biplist
try:
print('Writing out (using biplist) .. ' + output_path)
biplist.writePlist(deserialised_plist, output_path)
return True
except (biplist.InvalidPlistException, biplist.NotBinaryPlistException, OSError) as ex:
print('Had an exception (error)')
traceback.print_exc()
示例5: dump
# 需要導入模塊: import plistlib [as 別名]
# 或者: from plistlib import FMT_BINARY [as 別名]
def dump(value, fp, fmt=FMT_XML, sort_keys=True, skipkeys=False):
if _check_py3():
plistlib.dump(value, fp, fmt=fmt, sort_keys=sort_keys, skipkeys=skipkeys)
else:
if fmt == FMT_XML:
# We need to monkey patch a bunch here too in order to avoid auto-sorting
# of keys
writer = plistlib.PlistWriter(fp)
def writeDict(d):
if d:
writer.beginElement("dict")
items = sorted(d.items()) if sort_keys else d.items()
for key, value in items:
if not isinstance(key, basestring):
if skipkeys:
continue
raise TypeError("keys must be strings")
writer.simpleElement("key", key)
writer.writeValue(value)
writer.endElement("dict")
else:
writer.simpleElement("dict")
writer.writeDict = writeDict
writer.writeln("<plist version=\"1.0\">")
writer.writeValue(value)
writer.writeln("</plist>")
elif fmt == FMT_BINARY:
# Assume binary at this point
writer = _BinaryPlistWriter(fp, sort_keys=sort_keys, skipkeys=skipkeys)
writer.write(value)
else:
# Not a proper format
raise ValueError("Unsupported format: {}".format(fmt))
示例6: print_info
# 需要導入模塊: import plistlib [as 別名]
# 或者: from plistlib import FMT_BINARY [as 別名]
def print_info(self, post_data):
print ("[*] Found one..")
z = plistlib.loads(post_data, fmt=plistlib.FMT_BINARY)['SenderRecordData']
result = re.search('<key>ValidatedPhoneHashes</key>(.*)</array>', str(z))
rez = result.group(1)
if rez:
rez = rez.replace("<array>",'').replace("<string>",'').replace("</string>",'').replace("\\n",'').replace("\\t",'')
# print (rez)
devices.append({"ip":self.client_address[0],"hash":rez, "phone":""})
logger.debug("IPv6:{}\nPhone hash: {}".format(self.client_address[0],rez))
示例7: handle_ask
# 需要導入模塊: import plistlib [as 別名]
# 或者: from plistlib import FMT_BINARY [as 別名]
def handle_ask(self):
content_length = int(self.headers['Content-Length'])
post_data = self.rfile.read(content_length)
AirDropUtil.write_debug(self.config, post_data, 'receive_ask_request.plist')
ask_response = {'ReceiverModelName': self.config.computer_model,
'ReceiverComputerName': self.config.computer_name}
ask_resp_binary = plistlib.dumps(ask_response, fmt=plistlib.FMT_BINARY)
AirDropUtil.write_debug(self.config, ask_resp_binary, 'receive_ask_response.plist')
self._set_response(len(ask_resp_binary))
self.wfile.write(ask_resp_binary)
示例8: send_discover
# 需要導入模塊: import plistlib [as 別名]
# 或者: from plistlib import FMT_BINARY [as 別名]
def send_discover(self):
# discover_body = {}
a = '/root/.opendrop/debug/receive_discover_request.plist'
discover_body = plistlib.readPlist(a)
if self.config.record_data:
discover_body['SenderRecordData'] = self.config.record_data
discover_plist_binary = plistlib.dumps(discover_body, fmt=plistlib.FMT_BINARY)
# print (discover_plist_binary)
success, response_bytes = self.send_POST('/Discover', discover_plist_binary)
response = plistlib.loads(response_bytes)
# print (response)
# if name is returned, then receiver is discoverable
return response
示例9: dump
# 需要導入模塊: import plistlib [as 別名]
# 或者: from plistlib import FMT_BINARY [as 別名]
def dump(value, fp, fmt=FMT_XML, sort_keys=True, skipkeys=False):
if _check_py3():
plistlib.dump(value, fp, fmt=fmt, sort_keys=sort_keys, skipkeys=skipkeys)
else:
if fmt == FMT_XML:
# We need to monkey patch a bunch here too in order to avoid auto-sorting
# of keys
writer = plistlib.PlistWriter(fp)
def writeDict(d):
if d:
writer.beginElement("dict")
items = sorted(d.items()) if sort_keys else d.items()
for key, value in items:
if not isinstance(key, (str,unicode)):
if skipkeys:
continue
raise TypeError("keys must be strings")
writer.simpleElement("key", key)
writer.writeValue(value)
writer.endElement("dict")
else:
writer.simpleElement("dict")
writer.writeDict = writeDict
writer.writeln("<plist version=\"1.0\">")
writer.writeValue(value)
writer.writeln("</plist>")
elif fmt == FMT_BINARY:
# Assume binary at this point
writer = _BinaryPlistWriter(fp, sort_keys=sort_keys, skipkeys=skipkeys)
writer.write(value)
else:
# Not a proper format
raise ValueError("Unsupported format: {}".format(fmt))
示例10: test_dump_duplicates
# 需要導入模塊: import plistlib [as 別名]
# 或者: from plistlib import FMT_BINARY [as 別名]
def test_dump_duplicates(self):
# Test effectiveness of saving duplicated objects
for x in (None, False, True, 12345, 123.45, 'abcde', b'abcde',
datetime.datetime(2004, 10, 26, 10, 33, 33),
plistlib.Data(b'abcde'), bytearray(b'abcde'),
[12, 345], (12, 345), {'12': 345}):
with self.subTest(x=x):
data = plistlib.dumps([x]*1000, fmt=plistlib.FMT_BINARY)
self.assertLess(len(data), 1100, repr(data))
示例11: test_identity
# 需要導入模塊: import plistlib [as 別名]
# 或者: from plistlib import FMT_BINARY [as 別名]
def test_identity(self):
for x in (None, False, True, 12345, 123.45, 'abcde', b'abcde',
datetime.datetime(2004, 10, 26, 10, 33, 33),
plistlib.Data(b'abcde'), bytearray(b'abcde'),
[12, 345], (12, 345), {'12': 345}):
with self.subTest(x=x):
data = plistlib.dumps([x]*2, fmt=plistlib.FMT_BINARY)
a, b = plistlib.loads(data)
if isinstance(x, tuple):
x = list(x)
self.assertEqual(a, x)
self.assertEqual(b, x)
self.assertIs(a, b)
示例12: test_parse_binary_plist
# 需要導入模塊: import plistlib [as 別名]
# 或者: from plistlib import FMT_BINARY [as 別名]
def test_parse_binary_plist(self):
data = {"key": "value"}
in_data = tags.raw_tag("plst", plistlib.dumps(data, fmt=plistlib.FMT_BINARY))
parsed = parser.parse(in_data, lookup_tag)
self.assertEqual(1, len(parsed))
self.assertEqual(data, parser.first(parsed, "plst"))
示例13: play_url
# 需要導入模塊: import plistlib [as 別名]
# 或者: from plistlib import FMT_BINARY [as 別名]
def play_url(self, url, position=0):
"""Play media from an URL on the device."""
body = {
"Content-Location": url,
"Start-Position": position,
"X-Apple-Session-ID": str(uuid4()),
}
retry = 0
while retry < PLAY_RETRIES:
_LOGGER.debug("Starting to play %s", url)
# pylint: disable=no-member
_, status = await self.http.post_data(
"play",
headers=HEADERS,
data=plistlib.dumps(body, fmt=plistlib.FMT_BINARY),
)
# Sometimes AirPlay fails with "Internal Server Error", we
# apply a "lets try again"-approach to that
if status == 500:
retry += 1
_LOGGER.debug(
"Failed to stream %s, retry %d of %d", url, retry, PLAY_RETRIES
)
await asyncio.sleep(1.0, loop=self.loop)
continue
# TODO: Should be more fine-grained
if 400 <= status < 600:
raise exceptions.AuthenticationError("Status code: " + str(status))
await self._wait_for_media_to_end()
return
raise exceptions.PlaybackError("Max retries exceeded")
# Poll playback-info to find out if something is playing. It might take
# some time until the media starts playing, give it 5 seconds (attempts)
示例14: read_bplist
# 需要導入模塊: import plistlib [as 別名]
# 或者: from plistlib import FMT_BINARY [as 別名]
def read_bplist(data, start, length):
"""Extract a binary plist from a position in a sequence."""
# TODO: pylint doesn't find FMT_BINARY, why?
# pylint: disable=no-member
return plistlib.loads(data[start : start + length], fmt=plistlib.FMT_BINARY)
示例15: alert_discovery
# 需要導入模塊: import plistlib [as 別名]
# 或者: from plistlib import FMT_BINARY [as 別名]
def alert_discovery(self, post_data):
try:
z = plistlib.loads(post_data, fmt=plistlib.FMT_BINARY)['SenderRecordData']
result = re.search('<key>ValidatedPhoneHashes</key>(.*)</array>', str(z))
rez = result.group(1)
if rez:
rez = rez.replace("<array>",'').replace("<string>",'').replace("</string>",'').replace("\\n",'').replace("\\t",'')
self.callback(
{"ip":self.client_address[0],"hash":rez, "phone":""}
)
logger.debug("IPv6:{}\nPhone hash: {}".format(self.client_address[0],rez))
except Exception as e:
print(e)
pass