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

Резултати

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

Пребарај: #debug

当前筛选 #debug清除筛选
Harukaの异想世界

@haruka_fantasy_world · Post #349 · 06.02.2026 г., 04:21

嗯, podman的kube兼容的实现也非常草台班子 起因是把k8s带HTTP livenessProbe的pod移植到podman上运行, 发现healthcheck始终失败, 翻源码发现这部分实现非常难评, 是进入容器调用curl localhost实现的, 并不是像kubelet那样从容器外部访问 也就是说, 如果容器是精简过或者做了安全加固, 没有自带curl来做http get, 那livenessProbe无论如何都不会成功 https://github.com/containers/podman/blob/be85287fcf4590961614ee37be65eeb315e5d9ff/pkg/specgen/generate/kube/kube.go#L689 #Debug

Hashtags

Harukaの异想世界

@haruka_fantasy_world · Post #322 · 11.12.2025 г., 19:24

被CMSIS-DSP的FFT创飞 (其实是没仔细读文档 arm官方文档明确指出了 arm_rfft_fast_f32 会原地修改输入缓冲区, 然而咱用库之前没仔细读文档 Due to the use of complex transform internally, the source buffer is modified by the rfft. 看到函数参数有输入和输出指针, 然后就想当然认为函数内部一定不会覆盖输入缓冲区, 再加上输入循环缓冲用的是zero-copy, 调用FFT也是直接传入了缓冲区指针, 所以相当于算了一次FFT后直接污染了整个缓冲区 #Debug

Hashtags

Harukaの异想世界

@haruka_fantasy_world · Post #171 · 07.10.2024 г., 09:41

TL;DR 容器内设置了错误的dns导致tailscale用了自带的dns解析control-plane的ip, 用一种奇怪的方式避开了防火墙的阻断 #Debug

Hashtags

Arcadia

@ningxueye · Post #33 · 19.03.2024 г., 09:40

aiokafka是根据获取到的metadata内的hostname和port去连接集群的,而我部署服务的环境无法解析集群内的hostname…… 吃了不熟悉Kafka的亏。 #debug

Hashtags

Harukaの异想世界

@haruka_fantasy_world · Post #272 · 21.07.2025 г., 15:43

最近在研究SDN, 结果闹出了在内网ARP查询外网IP这种抽象事 bro先是实现了带Learning的Bridge, 然后手搓了ARP Proxy, 但是没判断IP范围, 代码认为世界是个巨大的交换机, 所有IP都在LAN, 都能用ARP查出来对应的MAC ( 然后手机疯狂发送TCP SYN, 网桥也在内网里疯狂用ARP查询外网IP 回应想必是没有的, 然后手机就认为上不了网摆了, 绷 #日常#Debug

Ship Overboard

@Ship_Overboard · Post #833 · 30.08.2023 г., 04:32

#debug#洋屁 playing Valheim with friends started a Linux Dedicated Server w/ Azure Playfab Crossplay Support. can't connect server using IP and Playfab API always connecting > Unable to preload the following plugins: libparty.so checking libparty.so using > ldd libparty.so IT NEEDS libpulse-dev ??????? Why? Audio lib requested SRSLY? sudo apt install libpulse-dev all works...

djangoproject

@djangoproject · Post #323 · 29.04.2017 г., 08:15

https://pypi.python.org/pypi/django-debug-toolbar A configurable set of panels that display various #debug information about the current #request/#response. The #Django_Debug_Toolbar is a configurable set of panels that display various debug information about the current request/response and when clicked, display more details about the panel’s content. Here’s a screenshot of the toolbar in action:

GitHub Trends

@githubtrending · Post #15488 · 13.02.2026 г., 12:30

#swift#analysis#analytics#cocoapods#crashlytics#debug#debugger#debugging#hacktoberfest#layout_debugger#leak_detection#log#logs_analysis#networking#performance_analysis#sandbox#swift#swift6#ui#uikit#view DebugSwift is a comprehensive toolkit that simplifies debugging for Swift iOS apps by providing real-time monitoring of network requests, performance metrics (CPU, memory, FPS), crash reports, and app resources like keychain and user defaults. It includes interface tools for visualizing layouts with grid overlays and touch indicators, plus memory leak detection and console logging. The main benefit is that you can quickly identify and fix issues during development without leaving your app—just shake your device to toggle the debug panel, making troubleshooting faster and more efficient. https://github.com/DebugSwift/DebugSwift