S19解析

#ifndef CS19_H
#define CS19_H
 
#include <QFile>
 
const quint8 MAX_S19_LINE_COUNT_LENGHT = 76;
const quint8 MIN_S19_LINE_COUNT_LENGHT = 10;
const quint8 MAX_S19_LINE_LENGHT = 156;
 
typedef enum __tagS19ErrorCode
{
    S19_NO_ERROR = 0,
    S19_FORMAT_ERROR,
    S19_VERIFY_ERROR,
    S19_LENGHT_ERROR,
    S19_USERPAPR_EEROR,
}ES19ErrorCode;
 
typedef enum __tagS19Type
{
    S0 = 0,
    S1,
    S2,
    S3,
    S5,
    S7,
    S8,
    S9,
    S_MAX,
}emS19Type;
 
typedef struct __tagS19LineData
{
    emS19Type   type;
    quint8      count;
    quint32     address;
    quint8      data[100];
    quint8      checksum;
    quint8      datalen;
}stS19LineData;
 
class CS19
{
public:
    CS19();
    ES19ErrorCode getS19LineData(QByteArray bydata,stS19LineData *p);
 
private:
    char ConvertHexChar(char ch);
};
 
#endif // CS19_H

 

#include "Cs19.h"
 
const QString S19TypeTable[8] =
{
    "S0","S1","S2","S3","S5","S7","S8","S9"
};
 
CS19::CS19()
{
 
}
 
char CS19::ConvertHexChar(char ch)
{
    if((ch >= '0') && (ch <= '9'))
        return (ch-0x30);
    else if((ch >= 'A') && (ch <= 'F'))
        return ((ch-'A')+10);
    else if((ch >= 'a') && (ch <= 'f'))
        return ((ch-'a')+10);
    else return (-1);
}
 
ES19ErrorCode CS19::getS19LineData(QByteArray bydata,stS19LineData *p)
{
    quint16 i = 0;
    quint8 cs_temp = 0;
    QString str(bydata);
    char *pcdata = bydata.data();
    quint32 linelen = str.size();
 
    if(linelen < MIN_S19_LINE_COUNT_LENGHT)
    {
        qDebug("S19_LENGHT_ERROR");
        return S19_LENGHT_ERROR;
    }
 
    //获取Type
    QString stype = str.mid(0,2);
    for(i = 0; i < S_MAX; i++)
    {
        if(stype == S19TypeTable[i])
        {
            p->type = (emS19Type)i;
            break;
        }
    }
    if(i == S_MAX) {qDebug("S19_FORMAT_ERROR");return S19_FORMAT_ERROR;}
 
    //获取count
    p->count = (ConvertHexChar(*(pcdata + 2)) << 4) | ConvertHexChar(*(pcdata + 3));
    cs_temp += p->count;
    if(p->count != ((linelen / 2) - 3))
    {
        qDebug("S19_FORMAT_ERROR");
        return S19_FORMAT_ERROR;
    }
    //获取address
    if(p->type == S0)//2 Bytes:0x0000填充
    {
        p->address = 0x0;
    }
    else if((p->type == S1) || (p->type == S5) || (p->type == S9))//2 Bytes
    {
        p->address = (ConvertHexChar(*(pcdata + 4)) << 12) | \
                     (ConvertHexChar(*(pcdata + 5)) << 8) | \
                     (ConvertHexChar(*(pcdata + 6)) << 4) | \
                     (ConvertHexChar(*(pcdata + 7)));
 
        cs_temp += (p->address >> 8) & 0x0FF;
        cs_temp += p->address & 0x0FF;
 
        //获取data
        for(i = 0; i < p->count - 3; i++)
        {
            p->data[i] = (ConvertHexChar(*(pcdata + 2*i + 8)) << 4) | ConvertHexChar(*(pcdata + 2*i + 9));
            cs_temp += p->data[i];
        }
        //获取checksum
        p->checksum = (ConvertHexChar(*(pcdata + 2*i + 8)) << 4) | ConvertHexChar(*(pcdata + 2*i + 9));
        if(p->checksum != (0xFF - cs_temp))
        {
            qDebug("S19_VERIFY_ERROR");
            return S19_VERIFY_ERROR;
        }
    }
    else if((p->type == S2) || (p->type == S8))//3 Bytes
    {
        p->address = (ConvertHexChar(*(pcdata + 4)) << 20) | \
                     (ConvertHexChar(*(pcdata + 5)) << 16) | \
                     (ConvertHexChar(*(pcdata + 6)) << 12) | \
                     (ConvertHexChar(*(pcdata + 7)) << 8) | \
                     (ConvertHexChar(*(pcdata + 8)) << 4) | \
                     (ConvertHexChar(*(pcdata + 9)));
 
        cs_temp += (p->address >> 16) & 0x0FF;
        cs_temp += (p->address >> 8) & 0x0FF;
        cs_temp += p->address & 0x0FF;
 
        //获取data
        for(i = 0; i < p->count - 4; i++)
        {
            p->data[i] = (ConvertHexChar(*(pcdata + 2*i + 10)) << 4) | ConvertHexChar(*(pcdata + 2*i + 11));
            cs_temp += p->data[i];
        }
        //获取checksum
        p->checksum = (ConvertHexChar(*(pcdata + 2*i + 10)) << 4) | ConvertHexChar(*(pcdata + 2*i + 11));
        if(p->checksum != (0xFF - cs_temp))
        {
            qDebug("S19_VERIFY_ERROR");
            return S19_VERIFY_ERROR;
        }
    }
    else if((p->type == S3) || (p->type == S7))//4 Bytes
    {
        p->address = (ConvertHexChar(*(pcdata + 4)) << 28) | \
                     (ConvertHexChar(*(pcdata + 5)) << 24) | \
                     (ConvertHexChar(*(pcdata + 6)) << 20) | \
                     (ConvertHexChar(*(pcdata + 7)) << 16) | \
                     (ConvertHexChar(*(pcdata + 8)) << 12) | \
                     (ConvertHexChar(*(pcdata + 9)) << 8) | \
                     (ConvertHexChar(*(pcdata + 10)) << 4) | \
                     (ConvertHexChar(*(pcdata + 11)));
 
        cs_temp += (p->address >> 24) & 0x0FF;
        cs_temp += (p->address >> 16) & 0x0FF;
        cs_temp += (p->address >> 8) & 0x0FF;
        cs_temp += p->address & 0x0FF;
 
        //获取data
        for(i = 0; i < p->count - 5; i++)
        {
            p->data[i] = (ConvertHexChar(*(pcdata + 2*i + 12)) << 4) | ConvertHexChar(*(pcdata + 2*i + 13));
            cs_temp += p->data[i];
        }
        //获取checksum
        p->checksum = (ConvertHexChar(*(pcdata + 2*i + 12)) << 4) | ConvertHexChar(*(pcdata + 2*i + 13));
        if(p->checksum != (0xFF - cs_temp))
        {
            qDebug("S19_VERIFY_ERROR");
            return S19_VERIFY_ERROR;
        }
    }
    //获取datalen
    //if(p->type == S0)       p->datalen = p->count - 3;
    if(p->type == S1)  p->datalen = p->count - 3;
    else if(p->type == S2)  p->datalen = p->count - 4;
    else if(p->type == S3)  p->datalen = p->count - 5;
    else                    p->datalen = 0;
 
    return S19_NO_ERROR;
}

 

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: S19是一种十六进制文件格式,通常用于存储嵌入式系统的代码和数据。Python作为一种高级编程语言,具有丰富的库和工具,可以用来解析S19文件。 要解析S19文件,首先需要读取文件并解析其格式。Python中可以使用文件读取操作来读取文件,并使用字符串分割、正则表达式等方法来解析S19格式。具体来说,可以根据S19文件的规则结构逐行读取文件,先判断是否为S19记录类别,再根据记录长度读取记录数据,并结合校验和验证数据的准确性。 另外,Python中还有许多S19解析库和工具可供使用,如IntelHex和SRecord等,它们都是专门用于解析各种嵌入式系统代码文件的开源工具,使用起来非常方便。通过使用这些工具,我们可以快速地将S19文件转换为可执行代码或数据。 总之,Python解析S19文件需要通过逐行读取文件、解析记录格式、校验数据等工作,并结合使用S19解析库和工具,方便快捷地将S19文件转换为可执行代码或数据。 ### 回答2: S19是一种十六进制文件格式,其中包含了嵌入式系统的代码和数据。Python提供了解析S19文件的功能,可通过Python模块来读取和处理S19文件。Python代码的应用可以帮助我们轻松地提取指令和数据信息,以便分析、调试或修改嵌入式系统。 Python中主要有两种方法来解析S19文件:基于字符串的解析和基于二进制数据的解析。基于字符串的解析是将S19文件读取到内存中,然后以字符串的形式对其进行分析。而基于二进制数据的解析则是将S19文件首先转换成二进制数据,然后以字节流的形式进行解析。 对于基于字符串的解析,Python提供了re模块,可以利用正则表达式来匹配S19文件中的记录类型,地址和数据信息等。而二进制数据解析的方法则可以使用struct模块。通过定义解构体来解析不同类型的记录,例如S1、S2和S3等。同时,还可以使用位运算符来获取记录的类型、地址和数据信息等。 需要注意的是,在解析S19文件时应考虑文件的完整性和合法性。因此,我们需要对文件进行验证,以确保文件格式正确,记录序号连续,以及数据校验和正确等。最后,我们也需注意对解析结果进行验证和调试,确保解析结果的准确性和可靠性。 ### 回答3: S19文件是一种记录程序或数据的文件格式,并且在微处理器中广泛应用。Python可以用来解析S19文件,具体来说,它可以用来读取文件中的地址、记录类型、校验和等信息。S19文件具有自己的记录格式和校验和算法,因此需要特殊的阅读器才能读取和处理。在Python中,我们可以使用内置的文本解析库或第三方库来解析S19文件。具体而言,我们可以使用Python的readline()方法来读取每行记录,然后使用字符串处理方法来转换它们。解析S19文件的流程大致如下: 1. 打开S19文件并读取第一行记录,它应该以"S0"为开头。 2. 遍历文件中的每一个记录,将每个记录解析S19文件格式。 3. 解析完记录后,校验和应该与文件中的校验和匹配。 4. 如果记录类型是"S1",则读取后面的16进制字节并将它们追加到内存中。 5. 如果记录类型是"S9",则文件处理完成。 6. 关闭文件并存储所加载的程序或数据。 Python提供了基本的S19文件解析库,但是使用第三方库如S19 Parser可能更方便。这些库通常提供了快速、准确的S19解析,还为错误处理和调试提供了丰富的工具。简而言之,Python解析S19可以通过内置库或第三方库进行,大大简化了数据的读取和处理过程,从而提高了效率和可靠性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值