Load, verify and use your line-formatted files easily.
maven
<dependencies>
<dependency>
<groupId>com.elbraulio</groupId>
<artifactId>ezload</artifactId>
<version>0.6.0</version>
</dependency>
</dependencies>
<repositories>
<repository>
<id>jitpack.io</id>
<url>https://jitpack.io</url>
</repository>
</repositories>
gradle
dependencies {
implementation 'com.elbraulio:ezload:0.6.0'
}
allprojects {
repositories {
maven { url 'https://jitpack.io' }
}
}
Load and validate formatted files with EzLoad and EzCol. You only have to define the file format by setting:
-
For file:
- Separation expression
- Number of columns
-
For each column:
- Position (starting at 0)
- Name
- Constraint
For instance, we have this csv:
2; Speed
3; Celcius
Then we can parse it like this:
String separation = ";";
int numberOfCols = 2;
Parser parser = EzLoad.parse(separation, numberOfCols)
.withCol(
EzCol.integer(
0, "value", new NoConstraint<>()
)
).withCol(
EzCol.string(
1, "name", s -> !s.isEmpty()
)
).parser();
Of course, a CSV may have null values and they must be defined as fixed text e.g. null
, NULL
, none
or even ""
(empty string). See this example:
2; Speed
3; null
EzLoad.parse(";", numberOfCols)
.withCol(
EzCol.integer(
0, "value", new NoConstraint<>()
)
).withCol(
EzCol.nullable(
"null",
EzCol.integer(
1, "name", s -> !s.isEmpty()
)
)
);
This notation allows ezload to check if a null value has been found in order to parse it as null
and not misread it as String in this case.
Another important feature is the implementation of actions to process your CSV using the Parser. For instance, ezload provide EzInsert action. This allows you to insert data from file source to a database. Also, optionally, you can specify a size to insert data by chunks when your files are large.
long insertedRows = EzInsert.fromParser(
connection, "table_name", parser, stream, chunkSize
);
To implement your own actions, keep reading and check the detailed explanation of them.
This tool inspects a stream of data looking for errors. It uses a Parser which has a defined model and rules.
Parser parser = EzLoad.parse(",", 2)
.withCol(EzCol.string(0, "name", new NoConstraint<>()))
.withCol(EzCol.string(1, "value", String::isEmpty))
.parser();
String[] data = new String[]{"speed,km/h", "weight,kg"};
List<EzError> errors = EzDoctor.check(parser, Stream.of(data));
As we know, a CSV is a file formatted by columns. So you have to define what those columns are. To do that you can use EzCol.
It defines the column's data type and constraint. You need to set the column format by providing its position on each CSV's line, name, constrain and optionally a way to transform the raw value.
EzCol.integer(
0, // column position
"name", // column name
i -> i > 0, // constraint
Integer::parseInt // transform the raw string to a type
);
Currently, these are the supported columns types
Type | EzCol |
---|---|
int | EzCol.integer |
double | EzCol.doublee |
String | EzCol.string |
LocalDateTime | EzCol.dateTime |
null | EzCol.nullable |
LocalDate | EzCol.date |
This allows ezload to check if a given column is right formatted. If it isn't, throws an Exception and gives you detailed information about what is wrong with the column.
You can define a Parser to check and parse a CSV. To build a Parser you must define the expression that splits the CSV, the number of columns and the format for each column using EzCol.
String separation = ";";
int numberOfCols = 2;
Parser parser = EzLoad.parse(separation, numberOfCols)
.withCol(
EzCol.integer(
0, "value", new NoConstraint<>()
)
).withCol(
EzCol.string(
1, "name", s -> !s.isEmpty()
)
).parser();
Now you can parse a raw line using parser.parse(rawLine)
and get a Line wich is a list of Values that can accept an Action. Check InsertFromParser implementation:
String raw;
while ((raw = bufferedReader.readLine()) != null) {
Line parsedLine = this.parser.parse(raw);
int index = 1;
for (Value value : parsedLine.values()) {
value.accept(new AddPreparedStatement(psmt, index++));
}
// ...
}
An Action make an operation over a Value depending on its type. Here you can see an example:
for (Value value : parsedLine.values()) {
value.accept(new SomeAction(...));
}
This means an Action must define what to do for each supported type. You can see here the Action's interface with has a method for each supported type.
We are using several bots, this is the current list:
name | description |
---|---|
Release Drafter | Drafts your next release notes as pull requests are merged into master. Built with Probot. |
wip | By default, WIP is setting a pull request status to pending if it finds one of the following terms in the pull request titles: wip, work in progress, 🚧. The pending status can be overwritten by adding @wip ready for review to the pull request body. |
Stale | A GitHub App built with Probot that closes abandoned Issues and Pull Requests after a period of inactivity. |
todo | Using todo should be really simple. Once you've installed it in your repository, simply push some code (to your default branch, a PR; doesn't matter). If the code you pushed includes one of the configured keywords (defaults are @todo and TODO ), then the integration will create a new issue for you using the comment your wrote in your code!To reduce noise and keep your todo notes in the right context, todo comments made in commits that are part of a pull request will be converted into comments on that pull request. When the PR is merged, todowill determine which of those todos have yet to be resolved and open an appropriate issue. |