Skip to content

Commit 4a5c1bd

Browse files
authored
Merge pull request #1 from spacious-team/develop
Релиз 2023.1
2 parents 82a2f24 + 892a108 commit 4a5c1bd

15 files changed

+943
-0
lines changed

.gitignore

+35
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,35 @@
1+
target/
2+
#.mvn
3+
!.mvn/wrapper/maven-wrapper.properties
4+
!**/src/main/**
5+
!**/src/test/**
6+
7+
### STS ###
8+
.apt_generated
9+
.classpath
10+
.factorypath
11+
.project
12+
.settings
13+
.springBeans
14+
.sts4-cache
15+
16+
### IntelliJ IDEA ###
17+
.idea
18+
*.iws
19+
*.iml
20+
*.ipr
21+
!.idea/runConfigurations
22+
!.idea/codeStyles
23+
!.idea/copyright
24+
!.idea/inspectionProfiles
25+
26+
### NetBeans ###
27+
/nbproject/private/
28+
/nbbuild/
29+
/dist/
30+
/nbdist/
31+
/.nb-gradle/
32+
build/
33+
34+
### VS Code ###
35+
.vscode/

.idea/codeStyles/Project.xml

+7
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.

.idea/codeStyles/codeStyleConfig.xml

+5
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.

.idea/copyright/GNU_AGPLv3.xml

+7
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.

.idea/copyright/profiles_settings.xml

+3
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.

.idea/inspectionProfiles/Inspections.xml

+26
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.

.idea/inspectionProfiles/profiles_settings.xml

+6
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.

.mvn/wrapper/maven-wrapper.properties

+18
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,18 @@
1+
# Licensed to the Apache Software Foundation (ASF) under one
2+
# or more contributor license agreements. See the NOTICE file
3+
# distributed with this work for additional information
4+
# regarding copyright ownership. The ASF licenses this file
5+
# to you under the Apache License, Version 2.0 (the
6+
# "License"); you may not use this file except in compliance
7+
# with the License. You may obtain a copy of the License at
8+
#
9+
# http://www.apache.org/licenses/LICENSE-2.0
10+
#
11+
# Unless required by applicable law or agreed to in writing,
12+
# software distributed under the License is distributed on an
13+
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
14+
# KIND, either express or implied. See the License for the
15+
# specific language governing permissions and limitations
16+
# under the License.
17+
distributionUrl=https://repo.maven.apache.org/maven2/org/apache/maven/apache-maven/3.8.1/apache-maven-3.8.1-bin.zip
18+
wrapperUrl=https://repo.maven.apache.org/maven2/org/apache/maven/wrapper/maven-wrapper/3.2.0/maven-wrapper-3.2.0.jar

README.md

+97
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,97 @@
1+
![java-version](https://img.shields.io/badge/Java-11-brightgreen?style=flat-square)
2+
[![spring-boot-version](https://img.shields.io/badge/spring--boot-2.7+-brightgreen?style=flat-square)](https://github.com/spring-projects/spring-boot/releases)
3+
[![jitpack-last-release](https://jitpack.io/v/spacious-team/table-wrapper-spring-boot-starter.svg?style=flat-square)](
4+
https://jitpack.io/#spacious-team/table-wrapper-api)
5+
6+
### Назначение
7+
Позволяет работать с табличным представлением данных в форматах Excel, Xml и Csv через единый интерфейс
8+
[Table Wrapper API](https://github.com/spacious-team/table-wrapper-api).
9+
10+
Совместим с проектами Spring Boot 2.7 и выше.
11+
12+
Spring Boot Starter настраивает реализации фабрик `ExcelTableFactory`, `XmlTableFactory`, `CsvTableFactory`
13+
и подключает необходимые зависимости
14+
1. [table-wrapper-excel-impl](https://github.com/spacious-team/table-wrapper-excel-impl) для работы с excel файлами
15+
```xml
16+
<dependency>
17+
<groupId>com.github.spacious-team</groupId>
18+
<artifactId>table-wrapper-excel-impl</artifactId>
19+
</dependency>
20+
```
21+
2. [table-wrapper-xml-impl](https://github.com/spacious-team/table-wrapper-xml-impl) для работы с xml файлами
22+
```xml
23+
<dependency>
24+
<groupId>com.github.spacious-team</groupId>
25+
<artifactId>table-wrapper-xml-impl</artifactId>
26+
</dependency>
27+
```
28+
3. [table-wrapper-csv-impl](https://github.com/spacious-team/table-wrapper-csv-impl) для работы с csv (tsv) файлами
29+
```xml
30+
<dependency>
31+
<groupId>com.github.spacious-team</groupId>
32+
<artifactId>table-wrapper-csv-impl</artifactId>
33+
</dependency>
34+
```
35+
36+
### Подключение стартера к проекту
37+
Необходимо подключить репозиторий open source библиотек github
38+
[jitpack](https://jitpack.io/#spacious-team/table-wrapper-spring-boot-starter), например для Apache Maven проекта
39+
```xml
40+
<repositories>
41+
<repository>
42+
<id>central</id>
43+
<name>Central Repository</name>
44+
<url>https://repo.maven.apache.org/maven2</url>
45+
<snapshots>
46+
<enabled>false</enabled>
47+
</snapshots>
48+
</repository>
49+
<repository>
50+
<id>jitpack.io</id>
51+
<url>https://jitpack.io</url>
52+
</repository>
53+
</repositories>
54+
```
55+
Далее добавить зависимость
56+
```xml
57+
<dependency>
58+
<groupId>com.github.spacious-team</groupId>
59+
<artifactId>table-wrapper-spring-boot-starter</artifactId>
60+
<version>master-SNAPSHOT</version>
61+
</dependency>
62+
```
63+
64+
В качестве версии можно использовать:
65+
- версию [релиза](https://github.com/spacious-team/table-wrapper-spring-boot-starter/releases) на github;
66+
- паттерн `<branch>-SNAPSHOT` для сборки зависимости с последнего коммита выбранной ветки;
67+
- короткий десяти значный номер коммита для сборки зависимости с указанного коммита.
68+
69+
### Пример использования
70+
Определяются колонки таблицы вне зависимости от формата файла (excel, xml, csv и др.):
71+
```java
72+
@lombok.Getter
73+
@lombok.RequiredArgsConstructor
74+
enum TableHeader implements TableHeaderColumn {
75+
PRODUCT(PatternTableColumn.of("Товар")),
76+
PRICE(PatternTableColumn.of("Цена"));
77+
78+
private final TableColumn column;
79+
}
80+
```
81+
Извлекаем данные в описанном формате, например, из Excel файла через Stream API
82+
```java
83+
Workbook book = new XSSFWorkbook(xlsFileinputStream); // открываем Excel файл
84+
ReportPage reportPage = new ExcelSheet(book.getSheetAt(0)); // используем 1-ый лист Excel файла для поиска таблицы
85+
86+
// Регистронезависимо найдет ячейку с текстом "Таблица 1",
87+
// парсит следующую за ней строку как заголовок таблицы,
88+
// оставшиеся строки парсятся как данные до пустой строки или конца файла
89+
Table table = reportPage.create("таблица 1", TableHeader.class); // метод использует бин ExcelTableFactory для создания таблицы
90+
91+
// Извлекаем и обрабатываем строки таблицы
92+
table.stream()
93+
.forEach(row -> {
94+
String product = row.getStringCellValue(TableHeader.PRODUCT);
95+
BigDecimal price = getBigDecimalCellValue(TableHeader.PRICE);
96+
});
97+
```

jitpack.yml

+8
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,8 @@
1+
# Workaround for any java version not supported by Jitpack.io yet
2+
# https://github.com/jitpack/jitpack.io/issues/4260
3+
#before_install:
4+
# - wget https://github.com/sormuras/bach/raw/master/install-jdk.sh
5+
# - source install-jdk.sh --feature 15
6+
# - jshell --version
7+
jdk:
8+
- openjdk11

0 commit comments

Comments
 (0)