玩转Hex文件

嵌入式软件实战派 2020-10-18 00:00


00 关于Hex

Hex文件格式(本文讲的是Intel Hex)是好多好多年以前定义的格式,解析这文件的工具网上搜出来的也是一大摞一大摞的。记住,我们就别瞎折腾自己写一个了哦。我们要学会站在巨人的肩膀上做开发,别干那些重复又累人的活儿。

话说回来,常用的解析Hex文件的工具有:IntelHex(Python),bincopy(Python)以及SRecordizer(C++),当然还有其他的,如BIN2MOTbinex 等等。

今天,我就教大家用IntelHex来玩转Hex文件,玩起来,Hex和Bin是没区别的!

等等,如果你还不了解Hex文件格式,请戳《SREC、Hex、Bin等烧录文件格式完全解读》。

01 写Hex文件

如果你精通Hex文件格式,我也不介意你自己手动敲一个,但我教你个快捷的办法:

 from intelhex import IntelHex
ih = IntelHex() for i in range(256): ih[i] = i
ih.tofile("hex256.hex", format="hex") ih.tofile("hex256.bin", format="bin")

生成出来的是长这样的:

 :10000000000102030405060708090A0B0C0D0E0F78 :10001000101112131415161718191A1B1C1D1E1F68 :10002000202122232425262728292A2B2C2D2E2F58 :10003000303132333435363738393A3B3C3D3E3F48 :10004000404142434445464748494A4B4C4D4E4F38 :10005000505152535455565758595A5B5C5D5E5F28 :10006000606162636465666768696A6B6C6D6E6F18 :10007000707172737475767778797A7B7C7D7E7F08 :10008000808182838485868788898A8B8C8D8E8FF8 :10009000909192939495969798999A9B9C9D9E9FE8 :1000A000A0A1A2A3A4A5A6A7A8A9AAABACADAEAFD8 :1000B000B0B1B2B3B4B5B6B7B8B9BABBBCBDBEBFC8 :1000C000C0C1C2C3C4C5C6C7C8C9CACBCCCDCECFB8 :1000D000D0D1D2D3D4D5D6D7D8D9DADBDCDDDEDFA8 :1000E000E0E1E2E3E4E5E6E7E8E9EAEBECEDEEEF98 :1000F000F0F1F2F3F4F5F6F7F8F9FAFBFCFDFEFF88 :00000001FF

而其bin形式内容是:

另外,如果想将生产的hex文件当字符串使用,可以直接使用Python内置的StringIO,像这样:


 from io import StringIO from intelhex import IntelHex ih = IntelHex() ih[10] = 0x10 ih[11] = 0x11 ih[12] = 0x12 sio = StringIO() ih.write_hex_file(sio) hexstr = sio.getvalue() sio.close() print(hexstr)

 :03000A00101112C0
 :00000001FF

   

这里面这个strhex就是这个Hex文件的字符串形式,可以直接在代码里面使用。

02 读Hex文件

你不要看小这个读功能哦,它不但可以将Hex文件读出来使用,而且还可以将Bin文件读出来当Hex来使用。

1. load Hex文件
 ih = IntelHex() # create empty object ih.loadhex('hex256.hex') # load from hex #ih.loadfile('hex256.hex',format='hex') # also load from hex #ih.fromfile('hex256.hex',format='hex') # also load from hex

以上,这里有三种方法(loadhexloadfilefromfile)将Hex文件load进来,都是一样的结果。

2. load Bin文件

同样道理,我们来试试load Bin文件试试:

 ih = IntelHex() # create empty object ih.loadbin('hex256.bin') # load from bin #ih.fromfile('hex256.bin',format='bin') # also load from bin

以上办法,是将整个Bin文件load进去的,如果将这个Bin文件load到一个特定地址开始呢?

 ih1.loadbin('hex256.bin',offset=40) # load binary data and place them
注意这个load进去的文件,是从offset地址开始填充Bin内容的,offset之前的内容是用默认值替代的。

我们可以测试下:

 ih2 = IntelHex() # create empty object ih2.loadbin('hex256.bin',offset=40) print(ih2[38],ih2[39],ih2[40],ih2[41])
 255 255 0 1
3. 直接通过类参数来load Hex文件
 ih = IntelHex('hex256.hex')

这个多简单,但是注意,这种方法是load不了Bin文件的,当然,你可以用这种方法load一个初始化好的对象,如:


 ih = IntelHex(ih2)
4. 获取文件的内容

从上面的例子可以看到,我们可以直接从对象ih加个下标来取取内容。

要注意下,这个ih[x]取出来的值是整型的,范围是0-255,而这个x就是Bin内容的地址。

我们不止可以用ih[x]读数据,还能写数据,如ih[x] = y

实际上,这个取值和赋值是Python类里面的两个不同方法:__getitem____setitem__,如果你有超大量的数据要读或者写,效率就不说话那么高了。当然,如果你只是操作1MB以内的内容,也无所谓了。后续我会解释有没有提高效率的方法。

03 Hex转Bin

这个是比较常用的,其实也很简单,直接用tobinfile就可以解决。

 ih = IntelHex('hex256.hex') ih.tobinfile('hex2bin.bin')
我们还可以将Bin文件转换成Bin文件,呃呃……我是说提取你想要的片段
 ih2.tobinfile('hex2bin.bin', 35, 45)

注意,这个35是提取的起始地址,45是结束地址。

这个hex2bin.bin文件就是这样的:

 0000: FF FF FF FF FF 00 01 02 03 04 05

其中里面的FF就是默认值,其实我们可以用padding改变它,如果需要的话:

 ih2.padding = 0x55 ih2.tobinfile('hex2bin.bin', 35, 45)

这就变成了:

 0000: 55 55 55 55 55 00 01 02 03 04 05

这里有个做好的hex2bin.py脚本,非常方便使用

 Usage:
    python hex2bin.py [options] INFILE [OUTFILE]
 
 Arguments:
    INFILE     name of hex file for processing.
    OUTFILE     name of output file. If omitted then output
                will be writing to stdout.
 
 
 Options:
     -h, --help             this help message.
     -p, --pad=FF           pad byte for empty spaces (hex value).
     -r, --range=START:END   specify address range for writing output
                            (hex value).
                            Range can be in form 'START:' or ':END'.
     -l, --length=NNNN,
     -s, --size=NNNN         size of output (decimal value).

例如可以这样的:

 python hex2bin.py -r 0000:00FF foo.hex
04 Bin转Hex

倒过来也行,首先将Bin load成一个IntelHex对象,然后调用ih.tofile(fout, format='hex')即可

 ih2 = IntelHex()  ih2.loadbin('hex256.bin',offset=40) ih2.tofile('bin2hex.hex', format='hex')

到这里,你会发现,这跟转Bin不是一样的吗,是的,一样。只要你有一个IntelHex对象,你就可以随意转Hex或者Bin了。

这里有个做好的bin2hex.py脚本,非常方便使用

 Usage:
    python bin2hex.py [options] INFILE [OUTFILE]
 
 Arguments:
    INFILE     name of bin file for processing.
                Use '-' for reading from stdin.
 
    OUTFILE     name of output file. If omitted then output
                will be writing to stdout.
 
 Options:
     -h, --help             this help message.
     --offset=N             offset for loading bin file (default: 0).
05 将Bin或Hex内容打印出来

有时候,你是不是想想看看Bin文件里面的内容而要去找能显示Bin内容的编辑器啊,例如WinHex或者Notepad++的Hex插件。或者你想看看Hex文件里面的实际内存,而找不到理想的工具啊。

我这里有个简便的方法。

 ih2.dump()

呵呵,就这么简单粗暴。

当然,这个dump是有参数的,你可以根据你的需要做不同处理

 def dump(self, tofile=None, width=16, withpadding=False): """Dump object content to specified file object or to stdout if None. Format is a hexdump with some header information at the beginning, addresses on the left, and data on right.
@param tofile file-like object to dump to @param width number of bytes per line (i.e. columns) @param withpadding print padding character instead of '--' @raise ValueError if width is not a positive integer """

这里有个做好的hex2dump.py脚本,非常方便使用

 Usage:
    python hex2dump.py [options] HEXFILE
 
 Options:
     -h, --help             this help message.
     -r, --range=START:END   specify address range for dumping
                            (ascii hex value).
                            Range can be in form 'START:' or ':END'.
 
 Arguments:
    HEXFILE     name of hex file for processing (use '-' to read
                from stdin)
06 合并Hex

如果有两个Hex,想将他们合并成一个,你会怎么做?

IntelHex有现成的方法,也非常简便

 ih1 = IntelHex() ih2 = IntelHex()
ih1[0] = 0 ih1[1] = 1
ih2[1] = 11 ih2[5] = 5 ih2[6] = 6
ih1.merge(ih2, overlap='ignore')
ih1.dump()
 0000 00 01 -- -- -- 05 06 -- -- -- -- -- -- -- -- -- |..   ..         |

以上merge函数的参数overlap要注意下,有三种选择:

overlap='error', 表示如果ih1和ih2有重复的内容,运行这函数会产生Error;overlap='ignore',表示如果ih1和ih2有重复的内容,运行这函数会忽略ih2的这个重复值;overlap='replace',表示如果ih1和ih2有重复的内容,运行这函数会将ih2的重复值替换到ih1对应的位置。

另外,这个merge是不限于两个Hex的哦,Hex和Bin合并也行。

为了方便使用,这里有个现成的脚本hexmerge.py

 Usage:
    python hexmerge.py [options] FILES...
 
 Options:
     -h, --help             this help message.
     -o, --output=FILENAME   output file name (emit output to stdout
                             if option is not specified)
     -r, --range=START:END   specify address range for output
                            (ascii hex value).
                            Range can be in form 'START:' or ':END'.
     --no-start-addr         Don't write start addr to output file.
     --overlap=METHOD       What to do when data in files overlapped.
                            Supported variants:
                            * error -- stop and show error message (default)
                            * ignore -- keep data from first file that
                                        contains data at overlapped address
                            * replace -- use data from last file that
                                          contains data at overlapped address
 
 Arguments:
    FILES       list of hex files for merging
                (use '-' to read content from stdin)
 
 You can specify address range for each file in the form:
 
    filename:START:END
 
 See description of range option above.
 
 You can omit START or END, so supported variants are:
 
    filename:START:     read filename and use data starting from START addr
    filename::END       read filename and use data till END addr
 
 Use entire file content:
 
    filename
 or
    filename::
07 比较Hex或者Bin

对于比较Bin文件还好,找个BeyondCompare就非常直观地看到差异。如果要比较两个Hex呢,或者Hex和Bin比较呢?

 from intelhex import diff_dumps diff_dumps(ih1, ih2)
 --- a
 +++ b
 @@ -1 +1 @@
 -0000  00 01 -- -- -- 05 06 -- -- -- -- -- -- -- -- -- |..   ..         |
 +0000  -- 0B -- -- -- 05 06 -- -- -- -- -- -- -- -- -- | .   ..         |

熟悉Linux上的diff命令就很容易理解了,不详细解释这个diff格式了,有感兴趣可以网上搜索diff查看,很详细很容易理解。

为了方便使用,这里有个现成的脚本hexmerge.py

 hexdiff: diff dumps of 2 hex files.
 
 Usage:
    python hexdiff.py [options] FILE1 FILE2
 
 Options:
     -h, --help             this help message.
     -v, --version           version info.
08 Hex转C数组


 ih = IntelHex('hex256.hex')
data_prefix = "const unsigned char hexdata[] = \n{" data_subfix = "\n};\n"
print(data_prefix, end='')
for i, data in enumerate(ih.tobinarray()): if(i%16 == 0): print("\n ", end='') print("0x%02X, "%data, end='')
print(data_subfix)


 const unsigned char hexdata[] = { 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0A, 0x0B, 0x0C, 0x0D, 0x0E, 0x0F, 0x10, 0x11, 0x12, 0x13, 0x14, 0x15, 0x16, 0x17, 0x18, 0x19, 0x1A, 0x1B, 0x1C, 0x1D, 0x1E, 0x1F, 0x20, 0x21, 0x22, 0x23, 0x24, 0x25, 0x26, 0x27, 0x28, 0x29, 0x2A, 0x2B, 0x2C, 0x2D, 0x2E, 0x2F, 0x30, 0x31, 0x32, 0x33, 0x34, 0x35, 0x36, 0x37, 0x38, 0x39, 0x3A, 0x3B, 0x3C, 0x3D, 0x3E, 0x3F, 0x40, 0x41, 0x42, 0x43, 0x44, 0x45, 0x46, 0x47, 0x48, 0x49, 0x4A, 0x4B, 0x4C, 0x4D, 0x4E, 0x4F, 0x50, 0x51, 0x52, 0x53, 0x54, 0x55, 0x56, 0x57, 0x58, 0x59, 0x5A, 0x5B, 0x5C, 0x5D, 0x5E, 0x5F, 0x60, 0x61, 0x62, 0x63, 0x64, 0x65, 0x66, 0x67, 0x68, 0x69, 0x6A, 0x6B, 0x6C, 0x6D, 0x6E, 0x6F, 0x70, 0x71, 0x72, 0x73, 0x74, 0x75, 0x76, 0x77, 0x78, 0x79, 0x7A, 0x7B, 0x7C, 0x7D, 0x7E, 0x7F, 0x80, 0x81, 0x82, 0x83, 0x84, 0x85, 0x86, 0x87, 0x88, 0x89, 0x8A, 0x8B, 0x8C, 0x8D, 0x8E, 0x8F, 0x90, 0x91, 0x92, 0x93, 0x94, 0x95, 0x96, 0x97, 0x98, 0x99, 0x9A, 0x9B, 0x9C, 0x9D, 0x9E, 0x9F, 0xA0, 0xA1, 0xA2, 0xA3, 0xA4, 0xA5, 0xA6, 0xA7, 0xA8, 0xA9, 0xAA, 0xAB, 0xAC, 0xAD, 0xAE, 0xAF, 0xB0, 0xB1, 0xB2, 0xB3, 0xB4, 0xB5, 0xB6, 0xB7, 0xB8, 0xB9, 0xBA, 0xBB, 0xBC, 0xBD, 0xBE, 0xBF, 0xC0, 0xC1, 0xC2, 0xC3, 0xC4, 0xC5, 0xC6, 0xC7, 0xC8, 0xC9, 0xCA, 0xCB, 0xCC, 0xCD, 0xCE, 0xCF, 0xD0, 0xD1, 0xD2, 0xD3, 0xD4, 0xD5, 0xD6, 0xD7, 0xD8, 0xD9, 0xDA, 0xDB, 0xDC, 0xDD, 0xDE, 0xDF, 0xE0, 0xE1, 0xE2, 0xE3, 0xE4, 0xE5, 0xE6, 0xE7, 0xE8, 0xE9, 0xEA, 0xEB, 0xEC, 0xED, 0xEE, 0xEF, 0xF0, 0xF1, 0xF2, 0xF3, 0xF4, 0xF5, 0xF6, 0xF7, 0xF8, 0xF9, 0xFA, 0xFB, 0xFC, 0xFD, 0xFE, 0xFF, };

   

09 计算Hex的Checksum或者CRC

从以上的案例,我们可以学习到,可以通过对象加下标可以取值,那么我们也可以写个Checksum或CRC函数直接计算。

但是,这并非很好的方法,因为对于大数据量的Hex文件,这效率很低的。如果文件不是特别大,电脑内存允许的情况下,可以直接转成Bin再算Checksum,这样效率会高很多。

from intelhex import IntelHex import binascii
ih = IntelHex('hex256.hex')
val = binascii.crc32(ih.tobinarray()) print("CRC32 = 0x%08X"%val)
 CRC32 = 0x29058C73
10 获取Hex文件信息

Hex文件里会有很多空隙,会分成很多段,我们想查看或者获取这些信息,怎么做呢?

 ih = IntelHex() ih[1] = 1 ih[2] = 1 ih[3] = 1 ih[7] = 1 ih[8] = 1 ih[11] = 1 ih[12] = 1
print(ih.segments()) ih.tofile("hexsegments.hex", format='hex')
 [(1, 4), (7, 9), (11, 13)]

实际上这个segments获取的是从哪个地址到哪个地址是有内容的。

这里还有个更方便的方法,hexinfo.py

 hexinfo: summarize a hex file's contents.
 
 Usage:
    python hexinfo.py [options] FILE [ FILE ... ]
 
 Options:
     -h, --help             this help message.
     -v, --version           version info.

例如

 python hexinfo.py hexsegments.hex

得到的信息是:

 - file: './hexsegments.hex'
  data:
   - { first: 0x00000001, last: 0x00000003, length: 0x00000003 }
   - { first: 0x00000007, last: 0x00000008, length: 0x00000002 }
   - { first: 0x0000000B, last: 0x0000000C, length: 0x00000002 }

注:上文提到的脚本:

bin2hex.py

hex2bin.py

hex2dump.py

hexdiff.py

hexinfo.py

hexmerge.py


请见:

https://github.com/python-intelhex/intelhex


如果无法访问,在公众号对话框回复Hex获取下载链接。


下期预告:
玩转S19文件

>>>猜猜你喜欢
“嵌入式开发学脚本干嘛”之进制/Byte/Hex处理
关于CRC8/CRC16/CRC32,你要找的全部在这
SREC、Hex、Bin等烧录文件格式完全解读
我硬生生地把C代码塞进了Python和Ruby

嵌入式软件实战派 专注嵌入式软件开发领域知识传授,包括C语言精粹,RTOS原理与使用,MCU驱动开发,AUTOSAR搭建,软件架构方法设计等。
评论 (0)
  • 你是不是也有在公共场合被偷看手机或笔电的经验呢?科技时代下,不少现代人的各式机密数据都在手机、平板或是笔电等可携式的3C产品上处理,若是经常性地需要在公共场合使用,不管是工作上的机密文件,或是重要的个人信息等,民众都有防窃防盗意识,为了避免他人窥探内容,都会选择使用「防窥保护贴片」,以防止数据外泄。现今市面上「防窥保护贴」、「防窥片」、「屏幕防窥膜」等产品就是这种目的下产物 (以下简称防窥片)!防窥片功能与常见问题解析首先,防窥片最主要的功能就是用来防止他人窥视屏幕上的隐私信息,它是利用百叶窗的
    百佳泰测试实验室 2025-04-30 13:28 338浏览
  • 在智能硬件设备趋向微型化的背景下,语音芯片方案厂商针对小体积设备开发了多款超小型语音芯片方案,其中WTV系列和WT2003H系列凭借其QFN封装设计、高性能与高集成度,成为微型设备语音方案的理想选择。以下从封装特性、功能优势及典型应用场景三个方面进行详细介绍。一、超小体积封装:QFN技术的核心优势WTV系列与WT2003H系列均提供QFN封装(如QFN32,尺寸为4×4mm),这种封装形式具有以下特点:体积紧凑:QFN封装通过减少引脚间距和优化内部结构,显著缩小芯片体积,适用于智能门铃、穿戴设备
    广州唯创电子 2025-04-30 09:02 245浏览
  • 文/郭楚妤编辑/cc孙聪颖‍越来越多的企业开始蚕食动力电池市场,行业“去宁王化”态势逐渐明显。随着这种趋势的加强,打开新的市场对于宁德时代而言至关重要。“我们不希望被定义为电池的制造者,而是希望把自己称作新能源产业的开拓者。”4月21日,在宁德时代举行的“超级科技日”发布会上,宁德时代掌门人曾毓群如是说。随着宁德时代核心新品骁遥双核电池的发布,其搭载的“电电增程”技术也走进业界视野。除此之外,经过近3年试水,宁德时代在换电业务上重资加码。曾毓群认为换电是一个重资产、高投入、长周期的产业,涉及的利
    华尔街科技眼 2025-04-28 21:55 171浏览
  • 贞光科技代理品牌紫光国芯的车规级LPDDR4内存正成为智能驾驶舱的核心选择。在汽车电子国产化浪潮中,其产品以宽温域稳定工作能力、优异电磁兼容性和超长使用寿命赢得市场认可。紫光国芯不仅确保供应链安全可控,还提供专业本地技术支持。面向未来,紫光国芯正研发LPDDR5车规级产品,将以更高带宽、更低功耗支持汽车智能化发展。随着智能网联汽车的迅猛发展,智能驾驶舱作为人机交互的核心载体,对处理器和存储器的性能与可靠性提出了更高要求。在汽车电子国产化浪潮中,贞光科技代理品牌紫光国芯的车规级LPDDR4内存凭借
    贞光科技 2025-04-28 16:52 265浏览
  • 4月22日下午,备受瞩目的飞凌嵌入式「2025嵌入式及边缘AI技术论坛」在深圳深铁皇冠假日酒店盛大举行,此次活动邀请到了200余位嵌入式技术领域的技术专家、企业代表和工程师用户,共享嵌入式及边缘AI技术的盛宴!1、精彩纷呈的展区产品及方案展区是本场活动的第一场重头戏,从硬件产品到软件系统,从企业级应用到高校教学应用,都吸引了现场来宾的驻足观看和交流讨论。全产品矩阵展区展示了飞凌嵌入式丰富的产品线,从嵌入式板卡到工控机,从进口芯片平台到全国产平台,无不体现出飞凌嵌入式在嵌入式主控设备研发设计方面的
    飞凌嵌入式 2025-04-28 14:43 157浏览
  • 晶振在使用过程中可能会受到污染,导致性能下降。可是污染物是怎么进入晶振内部的?如何检测晶振内部污染物?我可不可以使用超声波清洗?今天KOAN凯擎小妹将逐一解答。1. 污染物来源a. 制造过程:生产环境不洁净或封装密封不严,可能导致灰尘和杂质进入晶振。b. 使用环境:高湿度、温度变化、化学物质和机械应力可能导致污染物渗入。c. 储存不当:不良的储存环境和不合适的包装材料可能引发化学物质迁移。建议储存湿度维持相对湿度在30%至75%的范围内,有助于避免湿度对晶振的不利影响。避免雨淋或阳光直射。d.
    koan-xtal 2025-04-28 06:11 151浏览
  • 文/Leon编辑/cc孙聪颖‍2023年,厨电行业在相对平稳的市场环境中迎来温和复苏,看似为行业增长积蓄势能。带着对市场向好的预期,2024 年初,老板电器副董事长兼总经理任富佳为企业定下双位数增长目标。然而现实与预期相悖,过去一年,这家老牌厨电企业不仅未能达成业绩目标,曾提出的“三年再造一个老板电器”愿景,也因市场下行压力面临落空风险。作为“企二代”管理者,任富佳在掌舵企业穿越市场周期的过程中,正面临着前所未有的挑战。4月29日,老板电器(002508.SZ)发布了2024年年度报告及2025
    华尔街科技眼 2025-04-30 12:40 213浏览
  •  探针台的维护直接影响其测试精度与使用寿命,需结合日常清洁、环境控制、定期校准等多维度操作,具体方法如下:一、日常清洁与保养1.‌表面清洁‌l 使用无尘布或软布擦拭探针台表面,避免残留清洁剂或硬物划伤精密部件。l 探针头清洁需用非腐蚀性溶剂(如异丙醇)擦拭,检查是否弯曲或损坏。2.‌光部件维护‌l 镜头、观察窗等光学部件用镜头纸蘸取wu水jiu精从中心向外轻擦,操作时远离火源并保持通风。3.‌内部防尘‌l 使用后及时吹扫灰尘,防止污染物进入机械滑
    锦正茂科技 2025-04-28 11:45 111浏览
  • 一、智能家居的痛点与创新机遇随着城市化进程加速,现代家庭正面临两大核心挑战:情感陪伴缺失:超60%的双职工家庭存在“亲子陪伴真空期”,儿童独自居家场景增加;操作复杂度攀升:智能设备功能迭代导致用户学习成本陡增,超40%用户因操作困难放弃高阶功能。而WTR096-16S录音语音芯片方案,通过“语音交互+智能录音”双核驱动,不仅解决设备易用性问题,更构建起家庭成员间的全天候情感纽带。二、WTR096-16S方案的核心技术突破1. 高保真语音交互系统动态情绪语音库:支持8种语气模板(温柔提醒/紧急告警
    广州唯创电子 2025-04-28 09:24 191浏览
  • 一、gao效冷却与控温机制‌1、‌冷媒流动设计‌采用低压液氮(或液氦)通过毛细管路导入蒸发器,蒸汽喷射至样品腔实现快速冷却,冷却效率高(室温至80K约20分钟,至4.2K约30分钟)。通过控温仪动态调节蒸发器加热功率,结合温度传感器(如PT100铂电阻或Cernox磁场不敏感传感器),实现±0.01K的高精度温度稳定性。2、‌宽温区覆盖与扩展性‌标准温区为80K-325K,通过降压选件可将下限延伸至65K(液氮模式)或4K(液氦模式)。可选配475K高温模块,满足材料在ji端温度下的性能测试需求
    锦正茂科技 2025-04-30 13:08 263浏览
  • 网约车,真的“饱和”了?近日,网约车市场的 “饱和” 话题再度引发热议。多地陆续发布网约车风险预警,提醒从业者谨慎入局,这背后究竟隐藏着怎样的市场现状呢?从数据来看,网约车市场的“过剩”现象已愈发明显。以东莞为例,截至2024年12月底,全市网约车数量超过5.77万辆,考取网约车驾驶员证的人数更是超过13.48万人。随着司机数量的不断攀升,订单量却未能同步增长,导致单车日均接单量和营收双双下降。2024年下半年,东莞网约出租车单车日均订单量约10.5单,而单车日均营收也不容乐
    用户1742991715177 2025-04-29 18:28 227浏览
  • 在电子电路设计和调试中,晶振为电路提供稳定的时钟信号。我们可能会遇到晶振有电压,但不起振,从而导致整个电路无法正常工作的情况。今天凯擎小妹聊一下可能的原因和解决方案。1. 误区解析在硬件调试中,许多工程师在测量晶振时发现两端都有电压,例如1.6V,但没有明显的压差,第一反应可能是怀疑短路。晶振电路本质上是一个交流振荡电路。当晶振未起振时,两端会静止在一个中间电位,通常接近电源电压的一半。万用表测得的是稳定的直流电压,因此没有压差。这种情况一般是:晶振没起振,并不是短路。2. 如何判断真
    koan-xtal 2025-04-28 05:09 249浏览
  • 在CAN总线分析软件领域,当CANoe不再是唯一选择时,虹科PCAN-Explorer 6软件成为了一个有竞争力的解决方案。在现代工业控制和汽车领域,CAN总线分析软件的重要性不言而喻。随着技术的进步和市场需求的多样化,单一的解决方案已无法满足所有用户的需求。正是在这样的背景下,虹科PCAN-Explorer 6软件以其独特的模块化设计和灵活的功能扩展,为CAN总线分析领域带来了新的选择和可能性。本文将深入探讨虹科PCAN-Explorer 6软件如何以其创新的模块化插件策略,提供定制化的功能选
    虹科汽车智能互联 2025-04-28 16:00 187浏览
  • 随着电子元器件的快速发展,导致各种常见的贴片电阻元器件也越来越小,给我们分辨也就变得越来越难,下面就由smt贴片加工厂_安徽英特丽就来告诉大家如何分辨的SMT贴片元器件。先来看看贴片电感和贴片电容的区分:(1)看颜色(黑色)——一般黑色都是贴片电感。贴片电容只有勇于精密设备中的贴片钽电容才是黑色的,其他普通贴片电容基本都不是黑色的。(2)看型号标码——贴片电感以L开头,贴片电容以C开头。从外形是圆形初步判断应为电感,测量两端电阻为零点几欧,则为电感。(3)检测——贴片电感一般阻值小,更没有“充放
    贴片加工小安 2025-04-29 14:59 228浏览
  • 浪潮之上:智能时代的觉醒    近日参加了一场课题的答辩,这是医疗人工智能揭榜挂帅的国家项目的地区考场,参与者众多,围绕着医疗健康的主题,八仙过海各显神通,百花齐放。   中国大地正在发生着激动人心的场景:深圳前海深港人工智能算力中心高速运转的液冷服务器,武汉马路上自动驾驶出租车穿行的智慧道路,机器人参与北京的马拉松竞赛。从中央到地方,人工智能相关政策和消息如雨后春笋般不断出台,数字中国的建设图景正在智能浪潮中徐徐展开,战略布局如同围棋
    广州铁金刚 2025-04-30 15:24 193浏览
我要评论
0
2
点击右上角,分享到朋友圈 我知道啦
请使用浏览器分享功能 我知道啦