c#截取后几位_C#按规则获取byte[](如截取几个字节 与 几个字节 之前间字节)
public byte[] GetBytePart(byte[] data, byte[] startData,byte[] endData){int start = IndexOf(data, startData);int end = IndexOf(data, endData);if (start != -1 && end != -1){return data.Skip(sta
public byte[] GetBytePart(byte[] data, byte[] startData,byte[] endData)
{
int start = IndexOf(data, startData);
int end = IndexOf(data, endData);
if (start != -1 && end != -1)
{
return data.Skip(start).Take(end + endData.Length - start).ToArray();
}
else { return null; }
}
public int IndexOf(byte[] data, byte[] find)
{
for (int i = 0; i < data.Length - find.Length; i++)
{
if (data.Skip(i).Take(find.Length).SequenceEqual(find)) return i;
}
return -1;
}
//原创来自http://www.luofenming.com/show.aspx?id=ART2018100900001,如转载请保留此地址
以下是调用
//这是截取 byte[] { 0x11, 0x21, 0x31, 0xff, 0x10, 0x01, 0x12, 0x13, 0x0a, 0x20, 0x11 ,0x02}
//byte[] { 0x31, 0xff, 0x10 }, new byte[] { 0x0a, 0x20 }这两个字节数组之间的字节并且包含这两个字节数据
byte[] bytes = new byte[] { 0x11, 0x21, 0x31, 0xff, 0x10, 0x01, 0x12, 0x13, 0x0a, 0x20, 0x11 ,0x02};
byte[] b = GetBytePart(bytes, new byte[] { 0x31, 0xff, 0x10 }, new byte[] { 0x0a, 0x20 });
//得到的结果是 0x31, 0xff, 0x10, 0x01, 0x12, 0x13, 0x0a, 0x20
魔乐社区(Modelers.cn) 是一个中立、公益的人工智能社区,提供人工智能工具、模型、数据的托管、展示与应用协同服务,为人工智能开发及爱好者搭建开放的学习交流平台。社区通过理事会方式运作,由全产业链共同建设、共同运营、共同享有,推动国产AI生态繁荣发展。
更多推荐



所有评论(0)