EasyDbc 1.0.1
dotnet add package EasyDbc --version 1.0.1
NuGet\Install-Package EasyDbc -Version 1.0.1
<PackageReference Include="EasyDbc" Version="1.0.1" />
paket add EasyDbc --version 1.0.1
#r "nuget: EasyDbc, 1.0.1"
// Install EasyDbc as a Cake Addin #addin nuget:?package=EasyDbc&version=1.0.1 // Install EasyDbc as a Cake Tool #tool nuget:?package=EasyDbc&version=1.0.1
EasyDbc
<p align="right"> <a >English</a> | <a href="./README.zh.md">中文</a> | <a href="./README.de.md">Deutsch</a> | <a href="./README.kr.md">한국어</a> | <a href="./README.jp.md">日本語</a> | <a href="./README.fr.md">Français</a> </p>
Introduction
Brief introduction to the project's features and goals.
This project is developed based on DbcParserLib
and extends the following functionalities:
- DBC File Merging: Supports merging multiple DBC files.
- DBC File Generation: Can generate new DBC files based on requirements.
- Excel File Parsing to DBC: Provides functionality to parse Excel files into DBC files with flexible mapping and conversion.
- Excel File Generation: Supports generating Excel files from DBC data.
- Custom Excel Parsing and Generation Logic: Offers flexible custom logic for parsing and generating Excel files to meet different needs.
These extended functionalities make the project more flexible and efficient in handling DBC and Excel files, enhancing vehicle network management and signal processing capabilities.
Features
- Parse DBC Files: Supports extracting signals, messages, and node information.
- Data Display: Visually displays parsing results through an interactive interface.
- Format Validation: Flexible parsing of both old and new Excel formats.
- Extensibility: Provides flexible custom logic for Excel file parsing and generation.
Plugin References
This project refers to the NPOI
plugin when implementing Excel parsing and generation. NPOI
is an open-source .NET library for handling Microsoft Office file formats, including Excel, Word, and PowerPoint. The plugin is powerful and easy to use, particularly suited for various Excel file processing needs.
In this project, I primarily used the following features of the NPOI
plugin:
- Grouping: Supports grouping data based on specified rules for better display and management.
- Drop-down Menus: Implements drop-down menu functionality in Excel cells, simplifying user input and ensuring data consistency.
- Validation: Uses the data validation feature provided by
NPOI
to ensure that the data in Excel files complies with specified rules. - Background Color: Customizes the background color of Excel cells for better readability and visual effect.
- Cell Formatting: Supports setting cell formats, such as number formats, date formats, etc., to ensure correct data display.
By using NPOI
, this project can handle Excel files more flexibly, implement complex functionality requirements, and enhance data processing capabilities.
Project Structure
Project Root Directory/
├── EasyDbc/ # Source code folder
│ ├── Assets/ # Images and other auxiliary resources
│ ├── Contracts/ # Interface files
│ ├── Helpers/ # Extensions
│ ├── Models/ # Data models
│ ├── Observers/ # Error classes
│ ├── Parsers/ # Parser classes
│ ├── Generators/ # File generation classes
│ └── EasyDbc.csproj # Project file
├── DbcFiles/ # Resource files
├── EasyDbc.Benchmark/ # Performance test folder
├── EasyDbc.Test/ # Unit test folder
├── EasyDbc.Demo/ # Demo project folder
├── README.zh_CN.md # Chinese project documentation file
├── README.md # Project documentation file
└── LICENSE # License file
Quick Start
Program Demo
Here are some screenshots demonstrating the features and results of the project.
Example Description Screenshot:
Feature 1: DBC File Parsing
Parse the DBC file by specifying the path and successfully load its contents.
Run Screenshot:
Example Explanation:
- Input: Select a well-formed DBC file.
- Output: Successfully parses the file and displays signal list and message information.
Feature 2: Excel File Parsing and Generation
Supports parsing Excel files to DBC data models, and also generating Excel files based on user needs.
Run Screenshot:
Example Explanation:
- Feature Highlights:
- Custom logic parsing support.
- Flexibly generate Excel files with drop-down menus, data validation, and styling.
Feature 3: DBC File Merging
Merges multiple DBC files into one, resolving duplicate signals and conflicts.。
Run Screenshot:
Example Explanation:
- Input: Multiple DBC files to merge.
- Output: Generates a merged DBC file with customizable merging rules.
Summary
The above showcases some core features of the project. If you're interested in any specific features, please refer to the following sections for detailed usage instructions.
Add Namespace
// For DBC file and Excel file generation
using EasyDbc.Generators;
// For special signal parsing (e.g., signal.Parent.CycleTime(out var cycleTime))
using EasyDbc.Helpers;
// For associated models
using EasyDbc.Models;
// For DBC and Excel file parsing
using EasyDbc.Parsers;
Parsing DBC and Excel Files into Dbc
Classes
private bool TryParsingToFile(string path, out Dbc dbc)
{
string extension = Path.GetExtension(path)?.ToLower();
// Parse DBC file based on file path
if (extension == ".dbc")
{
dbc = Parser.ParseFromPath(path);
if (dbc != null)
{
return true;
}
return true;
}
else if (extension == ".xls" || extension == ".xlsx")
{
// Parse Excel file based on file path
ExcelParser excelParser = new ExcelParser();
ExcelParserState result = excelParser.ParseFirstSheetFromPath(path, out Dbc dbcOutput);
if (result == ExcelParserState.Success)
{
dbc = dbcOutput;
return true;
}
}
dbc = null;
return false;
}
Merging DBC Functionality Display: Can Be Customized Based on Actual Needs
⚠️ Important Note
Currently, the DBC merging feature will prioritize the first added message, invalidating any subsequent duplicate messages.
private bool ParsingAndMergeDbc()
{
Nodes = string.Empty;
Messages.Clear();
_mergedDbc = null;
List<Dbc> parsingResult = new List<Dbc>();
if (!string.IsNullOrEmpty(FilePath1))
{
if (TryParsingToFile(FilePath1, out Dbc dbc))
{
parsingResult.Add(dbc);
}
}
if (!string.IsNullOrEmpty(FilePath2))
{
if (TryParsingToFile(FilePath2, out Dbc dbc))
{
parsingResult.Add(dbc);
}
}
if (!string.IsNullOrEmpty(FilePath3))
{
if (TryParsingToFile(FilePath3, out Dbc dbc))
{
parsingResult.Add(dbc);
}
}
bool result = DbcGenerator.MergeDbc(parsingResult, out _mergedDbc);
if (result)
{
foreach (Node node in _mergedDbc.Nodes)
{
Nodes = string.Join("; ", _mergedDbc.Nodes.Select(node => node.Name));
}
}
return result;
}
DBC File Parsing
Use the static class Parser
to parse DBC files. Choose one parsing method:
// Parse by file path
Dbc dbc = Parser.ParseFromPath("C:\\your_dbc_file.dbc");
// Parse by stream
Dbc dbc = Parser.ParseFromStream(File.OpenRead("C:\\your_dbc_file.dbc"));
// Parse from a string
Dbc dbc = Parser.Parse("a dbc as string");
Handling DBC File Objects
The DBC
object contains two collections, Messages
and Nodes
, both of which are of type IEnumerable<T>
. You can use standard LINQ to access, iterate, and query them.
For example, get all messages with IDs greater than 100 and more than 2 signals:
var filteredSelection = dbc
.Messages
.Where(m => m.ID > 100 && m.Signals.Count > 2)
.ToArray();
Parsing Error Management
Use the IParseFailureObserver
interface to handle syntax errors during parsing. It provides methods for:
- General syntax errors (e.g., missing ;, ', ,)
- Duplicate object definitions (e.g., messages with the same ID, nodes, signals, custom properties)
- Missing object definitions (e.g., custom properties assigned before declaration)
- Value consistency (e.g., custom property values exceeding min/max range)
The library offers two implementations:
SilentFailureObserver
: Default implementation that suppresses errors during parsing.SimpleFailureObserver
: A simple observer that logs any errors:- Unknown syntax: No corresponding TAG syntax
- [TAG] Syntax error: Syntax error in a specific TAG
- Duplicated object: The parser found (and ignored) a duplicated object
- Object Not found: An object is declared or referenced before it is defined
- Property value out of bound: The value assigned to a property is below/above the minimum/maximum value defined for that property
- Property value out of index: The declared index value is not acceptable (for properties that support accessing values by index, like enum values)
The list of errors can be retrieved via the GetErrorList()
method:
// Comment out these two lines to remove error parsing management (errors will be silently handled)
// You can provide your own IParseFailureObserver implementation to customize error parsing management
var failureObserver = new SimpleFailureObserver();
Parser.SetParsingFailuresObserver(failureObserver);
var dbc = Parser.ParseFromPath(filePath);
var errors = failureObserver.GetErrorList();
Signal Packing and Unpacking
Simple Application Example
To pack and unpack signals, you can use the static Packer class.
Example of packing/unpacking a 14-bit signal with a minimum value of -61.92
and a maximum value of 101.91
:
Signal sig = new Signal
{
sig.Length = 14,
sig.StartBit = 2,
sig.IsSigned = 1,
sig.ByteOrder = 1, // 0 = Big Endian (Motorola), 1 = Little Endian (Intel)
sig.Factor = 0.01,
sig.Offset = 20
};
// Packing a signal to send
ulong TxMsg = Packer.TxSignalPack(-34.3, sig);
// This unpacks the received signal and calculates the corresponding physical value
double val = Packer.RxSignalUnpack(TxMsg, sig);
You can also pack multiple signals before sending them over CAN:
ulong TxMsg = 0;
TxMsg |= Packer.TxSignalPack(value1, sig1);
TxMsg |= Packer.TxSignalPack(value2, sig2);
TxMsg |= Packer.TxSignalPack(value3, sig3);
// ...
// Send TxMsg to the CAN bus.
Ensure that the signals do not overlap by correctly specifying Length
and StartBit
.
Multiplexed Signal Application Example
A message may contain multiplexed data, meaning its layout can change depending on the value of a multiplexer.
The Packer
class does not handle multiplexing, so users need to check if a given message indeed contains the signal.
For example, consider the following dbc file content:
BO_ 568 UI_driverAssistRoadSign: 8 GTW
SG_ UI_roadSign M : 0|8@1+ (1,0) [0|0] "" DAS
SG_ UI_dummyData m0 : 8|1@1+ (1,0) [0|0] "" Vector__XXX
SG_ UI_stopSignStopLineDist m1 : 8|10@1+ (0.25,-8) [-8|247.5] "m" Vector__XXX
The signal UI_dummyData
is only available when UI_roadSign
is 0, and UI_stopSignStopLineDist
is only available when UI_roadSign
is 1.
You can access multiplexing information by calling the following method:
var multiplexingInfo = signal.MultiplexingInfo();
if(multiplexingInfo.Role == MultiplexingRole.Multiplexor)
{
// This is a multiplexer!
}
else if(multiplexingInfo.Role == MultiplexingRole.Multiplexed)
{
Console.WriteLine($"This signal is multiplexed and will be available when multiplexor value is {multiplexingInfo.Group}");
}
You can also use the extension method to check if a message contains multiplexed signals:
if(message.IsMultiplexed())
{
// ...
}
Contributing
Welcome contributions! Feel free to submit pull requests to improve this library.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 is compatible. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 is compatible. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 is compatible. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 is compatible. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
.NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
.NET Standard | netstandard2.0 is compatible. netstandard2.1 was computed. |
.NET Framework | net461 was computed. net462 is compatible. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
MonoAndroid | monoandroid was computed. |
MonoMac | monomac was computed. |
MonoTouch | monotouch was computed. |
Tizen | tizen40 was computed. tizen60 was computed. |
Xamarin.iOS | xamarinios was computed. |
Xamarin.Mac | xamarinmac was computed. |
Xamarin.TVOS | xamarintvos was computed. |
Xamarin.WatchOS | xamarinwatchos was computed. |
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.