TGTGInsighttelegram intelligenceLIVE / telegram public index
← Python Заметки

TGINSIGHT SIMILAR POSTS

Најди сличен содржај

Изворен канал @pythonotes · Post #241 · 5 мај

Можно ли в Python создавать бинарные файлы? Конечно можно. Для этого в Python есть следующие инструменты: ▫️ тип данных bytes и bytearray ▫️ открытие файла в режиме wb (write binary) или rb (read binary) ▫️ модуль struct Про модуль struct поговорим в первую очередь. Файл в формате JSON или Yaml внутри себя содержит разметку данных. Всегда можно определить где список начался а где закончился. Где записана строка а где словарь. То есть формат записи данных содержит в себе элементы разметки данных. В binary-файле данные не имеют визуальной разметки. Это просто байты, записанные один за другим. Правила записи и чтения находятся вне файла. Модуль struct как раз и помогает с организацией данных в таком файле с помощью определения форматов записи для разных частей файла. Модуль struct преобразует Python-объекты в массив байт, готовый к записи в файл и имеющий определённый вид. Для этого всегда следует указывать формат преобразования (или, как оно здесь называется - запаковки). Формат нужен для того, чтобы выделить достаточное количество байт для записи конкретного типа объекта. В последствии с помощью того же формата будет производиться чтение. При этом следует помнить что мы говорим о типах языка С а не Python. Именно формат определяет, что записано в конкретном месте файла, число, строка или что-то еще. Вот какие токены формата у нас есть. Помимо этого, первым символом можно указать порядок байтов. На разных системах одни и те же типы данных могут записываться по-разному, поэтому желательно указать конкретный способ из доступных. Если этого не сделать, то используется символ '@', то есть нативный для текущей системы. В строке формата мы пишем в каком порядке и какие типы собираемся преобразовать в байты. Запакуем в байты простое число, токен "i". >>> import struct >>> struct.pack('=i', 10) b'\n\x00\x00\x00' Теперь несколько float, при этом нужно передавать элементы не массивом а последовательностью аргументов. >>> struct.pack('=fff', 1.0, 2.5, 4.1) b'\x00\x00\x80?\x00\x00 @33\x83@' Вместо нескольких токенов можно просто указать нужное количество элементов перед одним токеном, результат будет тот же. >>> struct.pack('=3f', 1.0, 2.5, 4.1) b'\x00\x00\x80?\x00\x00 @33\x83@' Теперь запакуем разные типы >>> data = struct.pack('=fiQ', 1.0, 4, 100500) я запаковал типы float, int и unsigned long long (очень большой int, на 8 байт) b'\x00\x00\x80?\x04\x00\x00...' Распаковка происходит аналогично, но нужно указать тот же формат, который использовался при запаковке. Результат возвращается всегда в виде кортежа. >>> struct.unpack('=fiQ', data) (1.0, 4, 100500) Как видите, ничего страшного! #lib#basic

Hashtags

Резултати

Пронајдени 5 слични објави

Пребарај: #chinaunicom

当前筛选 #chinaunicom清除筛选
不求甚解

@Fakeye · Post #12 · 04.11.2019 г., 01:54

#ChinaUnicom 联通用户在水深火热中啊。作为一个 7 年联通老粉,当年为了支持联通 FDD LTE 而抛弃了移动,可现在联通依旧信号覆盖弱,在目前阶段还涉嫌 4G 降速,让老用户有苦难言。 就拿前阶段的真实事情来说吧。公司园区联通信号堪忧,只要一进入电梯或者地下车库就没信号了,看到 Twitter 上有朋友通过工信部投诉解决了小区信号覆盖的问题。索性我也试试,于是在今年 8 月 20 日左右去工信部网站填了表,2 天后接到联通工作人员打来的电话,告知我所投诉的地点目前其实已经在做基站覆盖的施工了,但是苦于硬件设备迟迟没有到货所以还没有完成施工,现场人员反馈 10 月底可以完工,该工作人员表示将会一直跟踪我的投诉直至施工完成。目前已经 11 月了,信号问题仍然没有解决,上周联通的工作人员又打来电话,说是设备到货太晚了,现场人员反馈需要11 月底才能完成部署,让我耐心等等,他会一直跟踪。 所以说,从目前阶段来看,联通的信号覆盖问题真的是令人头痛,投诉后依然不受重视,不知道都忙着部署 5G 去了还是有什么其他原因。我现在唯一希望的就是 11 月底携号转网服务正式施行,马上转走 👋。

Hashtags