- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想阅读例如。十六进制 .bin 文件中的第 11 个和第 23 个数字如下所示:https://imgur.com/b4RzPjw ,将某些部分打印为整数或将其他部分打印为名称(字符串)。 (最好不使用任何[]
,仅对指针进行操作)
我的示例 .bin 文件包含:前 4 个十六进制数字(蓝色突出显示)是名称的长度,然后 2 个数字是 ASCII 形式的名称。接下来的4个数字(蓝色下划线)是姓氏的长度(红色下划线),最后一个数字是索引。
我的尝试:
将整个 .bin 文件加载到缓冲区后,与此处所示的完全一样:http://www.cplusplus.com/reference/cstdio/fread/ ,我痛苦地尝试了多种方法将此缓冲区的部分分配给变量(或结构),然后使用格式 printf 它,只是为了看看分配了什么。
char *name_length = malloc(4);
char *pEnd;
for(*buffer=0; *buffer<4; *buffer++) {
sscanf(buffer, "%s", name_length);
long int i = strtol (buffer, &pEnd, 16);
printf("%x", i);
}
上面(错误的)代码打印 0000 (我想它从根本上就已经完全腐烂了,尽管我不知道为什么);如果有一种优雅的方法来加载已经构建的缓冲区部分,这里是声明:
struct student_t
{
char name[20];
char surname[40];
int index;
};
我能得到的“最接近”结果是另一个代码,它打印“2000”。来 self 的 .bin 文件:“02 00 00 46 2E
”,这意味着“2
0 0 0/length/F.
/string/”
for(int i=0; i<4; i++)
printf("%d", buffer[i]); //it's supposed to print first 4 hex digits...
for(int j=5; j<7; j++)
printf("%s", &buffer[j]); //it's supposed to print from 5th to 7th...
非常感谢您的帮助和指导。
最佳答案
考虑到我将您的确切二进制数据保存在名为 data.bin 的文件中,下面是一个示例:
代码.c:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <inttypes.h>
#include <errno.h>
#define FILE_NAME "data.bin"
typedef struct Record_ {
uint32_t nameLen, surnameLen;
char *name, *surname;
} Record;
void printRecord(Record record) {
printf("\nPrinting record:\n Name length: %u\n Name: [", record.nameLen);
if ((record.nameLen != 0) && (record.name != NULL)) {
char *pc;
for (pc = record.name; pc < record.name + record.nameLen; pc++) {
printf("%c", *pc);
}
}
printf("]\n Surname length: %u\n Surname: [", record.surnameLen);
if ((record.surnameLen != 0) && (record.surname != NULL)) {
char *pc;
for (pc = record.surname; pc < record.surname + record.surnameLen; pc++) {
printf("%c", *pc);
}
}
printf("]\n");
}
void clearRecord(Record *pRecord) {
free(pRecord->name);
free(pRecord->surname);
memset(pRecord, 0, sizeof(Record));
}
int readRecord(FILE *pFile, Record *pRecord) {
size_t readBytes = fread(&pRecord->nameLen, sizeof(pRecord->nameLen), 1, pFile);
if (pRecord->nameLen != 0) {
pRecord->name = malloc(pRecord->nameLen);
readBytes= fread(pRecord->name, 1, pRecord->nameLen, pFile);
}
readBytes = fread(&pRecord->surnameLen, sizeof(pRecord->surnameLen), 1, pFile);
if (pRecord->surnameLen != 0) {
pRecord->surname = malloc(pRecord->surnameLen);
readBytes = fread(pRecord->surname, 1, pRecord->surnameLen, pFile);
}
return 0;
}
int main() {
FILE *fp = fopen(FILE_NAME, "r+b");
if (fp == NULL)
{
printf("Error opening file: %d\n", errno);
return 1;
}
Record record = {0, 0, NULL, NULL};
printRecord(record);
int ret = readRecord(fp, &record);
if (ret)
{
printf("readRecord returned %d\n", ret);
fclose(fp);
return 2;
}
printRecord(record);
clearRecord(&record);
fclose(fp);
return 0;
}
注释:
After loading entire .bin file to buffer exactly like presented here
通常,这不是一个好主意。只阅读您需要的内容。想象一下,您想要从数百 MiB 大的文件中读取 10 个字节。这完全是资源浪费,有时甚至可能导致崩溃
看来您这里有一个简单的协议(protocol):
uint32_t
char *
,因为它的长度在编译时未知(您可以有一个像这样的数组:char[SOME_MAX_NAME_LENGTH]
,您可以确定在前一个字段中永远不会有大于SOME_MAX_NAME_LENGTH
的值,但我更喜欢这种方法)<
这映射到Record
结构(是的,成员顺序并不重要,只有初始化顺序)。事情还可以更进一步,因为姓氏的数据与姓名的数据重复,因此可能存在一个包含姓名的内部结构em> data 和 Record
仅包含一个包含该结构的 2 个元素的数组。
但即使这样事情会更简单(而且函数中的代码也会更短 - 没有重复),我也没有这样做,因为它可能不太明显
printRecord
- 以用户友好的方式显示Record
数据(当printf
ing时,您可以注意到这里的指针逻辑单独的字符)
clearRecord
- 释放 char *
成员占用的内存并将所有内容初始化为0
readRecord
- 从文件读取数据并填充记录
fread
)sscanf
(函数系列)应该处理二进制数据(字符串除外))输出:
[cfati@cfati-ubtu16x64-0:~/Work/Dev/StackOverflow/q052085090]> gcc code.c -o code.exe && ./code.exe
Printing record:
Name length: 0
Name: []
Surname length: 0
Surname: []
Printing record:
Name length: 2
Name: [F.]
Surname length: 13
Surname: [MurrayAbraham]
关于c - 读取 .bin 文件的某些部分(例如从 11 日到 23 日): hex into int, 字符串。 C,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52085090/
bin、bin/、bin/*和bin/**有什么区别我的 .gitignore 文件?我一直在使用 bin/,但正在查看 other .gitignore files (在 eclipse file
给定 n 个无限容量的箱子,我想将 m 件元素装入其中(每个元素都有特定的重量),同时最小化最重箱子的重量。 这不是传统的垃圾箱包装/背包问题,其中垃圾箱的容量有限,而您试图尽量减少使用的垃圾箱数量;
Closed. This question is off-topic。它当前不接受答案。 想改善这个问题吗? Update the question,所以它是用于堆栈溢出的on-topic。 7年前关
我一直在寻找一个问题的解决方案,这个问题显然比我最初想象的更不寻常。 Optaplanner 看起来很有前途,但由于我对 Java 相对缺乏经验,所以我想在深入研究之前调查一下这是否完全不可能。 我正
我有一个琐碎的问题。我有一个非常大的 df 有很多列。我正在尝试找到最有效的方法来对具有不同 bin 大小的所有列进行 bin 并创建一个新的 df。这是一个仅对单个列进行分箱的示例: import
我想以这样的方式对数字列 (var) 进行分类,使每个分类中的行数大致相同。我的附加要求是该列中的一个(唯一)值不能分配给多个 bin。例如,如果 var 列中的值 1 分配给 bin 1,则不允许将
我在 centos (rhel 7)_ 上使用 make 命令和 gcc 7.1 通过代码进行编译,但遇到了以下错误: /bin/sh:/bin: 是一个目录 which sh 返回/usr/bin/
/usr/bin/ld: cannot find -ldlib /usr/bin/ld: cannot find -lcblas /usr/bin/ld: cannot find -llapack 在
我进行了一项眼动追踪实验,试图检测两个区域(感兴趣区域,名为“代理”和“患者”的 AOI)的注视分布。我将整个时间划分为时间段,例如得到以下列表: Stimulus Participant A
我正在尝试替换 whoami带有 ~/.local/bin/ 中的脚本的命令.有没有办法让我的 whoami 获得优先权,这样当我运行 whoami 时,我的脚本就会运行? 最佳答案 这就是我的 ~/
我的项目结构是这样的: . ├── Cargo.lock ├── Cargo.toml └── src ├── bin │ └── other.rs ├── main.rs
我正在开发一个小型图书馆应用程序,它以这种格式存储技术手册: 目前,我正在尝试将库的内容保存并根据用户的需要加载到 bin 文件中。 但是,当我尝试加载库文件时,唯一的变化是“-1”被打印到控制台。此
我试图忽略 Web 项目的 bin 文件夹,但包含该 bin 文件夹中的 .refresh 文件。 这是我的 .gitignore 中的内容: [Bb]in/ #Allow .refresh file
ipv6_hdr__f_next_header_cp: coverpoint this.ipv6_hdr.ipv6_f_next_header iff (this.has_ipv6_header){
今天有人给我发了一个以 #: 开头的脚本,谷歌搜索后我没有找到任何答案。 即使脚本有效,我想知道那是什么意思。 最佳答案 哇!这让我想起了很多记忆! 回到 1980 年代和 90 年代初期,有两种基本
我使用这个 ksh 函数将“1-Jan-2011”格式转换为“1.1.2011”。 #!/bin/ksh ##---- function to convert 3 char month into nu
我在 c# winform 项目中使用 sql-server compact 数据库。 如果我查看构成解决方案的文件,我可以在以下两个文件夹中看到 exe 和 sdf 文件的副本: /bin/Debu
这个问题与我上一个问题不同。我正在通过以下代码使用 facetgrid 打印直方图。 import numpy as np import pandas as pd import seaborn as
我有一个整数需要根据概率分布分成 bin。例如,如果我有 N=100 对象进入 [0.02, 0.08, 0.16, 0.29, 0.45] 那么你可能会得到 [1, 10, 20 , 25, 44]
我在寻找使用 Jenkins 运行 Appium 的脚本时阅读了以下脚本 #!/bin/bash --login killall -9 "iPhone Simulator" &> /dev/null
我是一名优秀的程序员,十分优秀!