Skip to content

Commit e6d0368

Browse files
Merge pull request #1 from SyncfusionExamples/934868
How to import an excel file into Flutter DataTable (SfDataGrid).
2 parents 45a8aab + 3cc34c2 commit e6d0368

File tree

125 files changed

+4839
-2
lines changed

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

125 files changed

+4839
-2
lines changed

.gitignore

Lines changed: 45 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,45 @@
1+
# Miscellaneous
2+
*.class
3+
*.log
4+
*.pyc
5+
*.swp
6+
.DS_Store
7+
.atom/
8+
.build/
9+
.buildlog/
10+
.history
11+
.svn/
12+
.swiftpm/
13+
migrate_working_dir/
14+
15+
# IntelliJ related
16+
*.iml
17+
*.ipr
18+
*.iws
19+
.idea/
20+
21+
# The .vscode folder contains launch configuration and tasks you configure in
22+
# VS Code which you may wish to be included in version control, so this line
23+
# is commented out by default.
24+
#.vscode/
25+
26+
# Flutter/Dart/Pub related
27+
**/doc/api/
28+
**/ios/Flutter/.last_build_id
29+
.dart_tool/
30+
.flutter-plugins
31+
.flutter-plugins-dependencies
32+
.pub-cache/
33+
.pub/
34+
/build/
35+
36+
# Symbolication related
37+
app.*.symbols
38+
39+
# Obfuscation related
40+
app.*.map.json
41+
42+
# Android Studio will place build artifacts here
43+
/android/app/debug
44+
/android/app/profile
45+
/android/app/release

README.md

Lines changed: 138 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -1,2 +1,138 @@
1-
# How-to-import-an-excel-file-into-Flutter-DataTable-
2-
This demo shows how to import an excel file into Flutter DataTable.
1+
# How to import an excel file into Flutter DataTable (SfDataGrid)?
2+
3+
In this article, we will show you how to import an excel file into [Flutter DataTable](https://www.syncfusion.com/flutter-widgets/flutter-datagrid).
4+
5+
## Steps to Import an Excel File into Flutter DataTable
6+
7+
### Step 1: Extracting Data from Excel
8+
9+
The file picker should allow the selection of .xlsx files. Once an Excel file is selected, decode it using the `Excel.decodeBytes` method from the excel package. Extract the headers from the first row and the data starting from the second row. Dynamically generate columns by iterating over the headers and creating a [GridColumn](https://pub.dev/documentation/syncfusion_flutter_datagrid/latest/datagrid/GridColumn-class.html) for each one.
10+
11+
```dart
12+
// Handle Excel file import and load data into the DataGrid.
13+
Future<void> importDataGridFromExcel() async {
14+
clearData();
15+
16+
// Picking an Excel file using FilePicker.
17+
FilePickerResult? result = await FilePicker.platform.pickFiles(
18+
type: FileType.custom,
19+
allowedExtensions: ['xlsx'],
20+
);
21+
22+
if (result != null) {
23+
Uint8List? fileBytes = result.files.first.bytes;
24+
if (fileBytes == null) {
25+
String? filePath = result.files.first.path;
26+
if (filePath != null) {
27+
fileBytes = await File(filePath).readAsBytes();
28+
}
29+
}
30+
31+
if (fileBytes != null) {
32+
var excel = Excel.decodeBytes(fileBytes);
33+
34+
for (var table in excel.tables.keys) {
35+
var sheet = excel.tables[table];
36+
// Extract headers from the first row of the sheet.
37+
List<String> headers =
38+
sheet!.row(0).map((cell) => cell!.value.toString()).toList();
39+
// Loop through the rows starting from the second row (skipping the header).
40+
for (int row = 1; row < sheet.maxRows; row++) {
41+
Map<String, dynamic> rowData = {};
42+
for (int col = 0; col < headers.length; col++) {
43+
rowData[headers[col]] = sheet.row(row)[col]!.value;
44+
}
45+
importedData.add(rowData);
46+
}
47+
}
48+
49+
if (importedData.isNotEmpty) {
50+
// Generate the columns.
51+
columns = generateColumns(importedData[0]);
52+
if (mounted) {
53+
Navigator.push(
54+
context,
55+
MaterialPageRoute(
56+
builder: (context) => DataGridPage(
57+
importedData: importedData,
58+
columns: columns,
59+
),
60+
),
61+
);
62+
}
63+
}
64+
}
65+
}
66+
}
67+
68+
// Clear previous data.
69+
void clearData() {
70+
importedData.clear();
71+
columns.clear();
72+
}
73+
74+
// Dynamically generate columns based on the imported data.
75+
List<GridColumn> generateColumns(Map<String, dynamic> data) {
76+
List<GridColumn> columns = [];
77+
78+
for (var entry in data.entries) {
79+
GridColumn gridColumn = GridColumn(
80+
columnName: entry.key,
81+
label: Container(
82+
padding: const EdgeInsets.all(8),
83+
alignment: Alignment.center,
84+
child: Text(entry.key),
85+
),
86+
);
87+
88+
columns.add(gridColumn);
89+
}
90+
91+
return columns;
92+
}
93+
```
94+
95+
### Step 2: Displaying Data in SfDataGrid
96+
97+
Display a CircularProgressIndicator while the data is loading. Once the data is loaded, pass the prepared DataGridSource to the [SfDataGrid]() widget to render the grid.
98+
99+
```dart
100+
late ExcelDataGridSource excelDataGridSource;
101+
bool isLoading = true;
102+
103+
@override
104+
void initState() {
105+
super.initState();
106+
loadData();
107+
}
108+
109+
// Simulate loading data and prepare the DataGrid source.
110+
Future<void> loadData() async {
111+
await Future.delayed(const Duration(seconds: 2));
112+
if (mounted) {
113+
setState(() {
114+
excelDataGridSource =
115+
ExcelDataGridSource(widget.importedData, widget.columns);
116+
isLoading = false;
117+
});
118+
}
119+
}
120+
121+
@override
122+
Widget build(BuildContext context) {
123+
return Scaffold(
124+
appBar: AppBar(
125+
title: const Text('DataGrid'),
126+
),
127+
body: isLoading
128+
? const Center(child: CircularProgressIndicator())
129+
: SfDataGrid(
130+
source: excelDataGridSource,
131+
columns: widget.columns,
132+
columnWidthMode: ColumnWidthMode.fill,
133+
),
134+
);
135+
}
136+
```
137+
138+
You can download this example on [GitHub](https://github.com/SyncfusionExamples/How-to-import-an-excel-file-into-Flutter-DataTable).

android/.gitignore

Lines changed: 13 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,13 @@
1+
gradle-wrapper.jar
2+
/.gradle
3+
/captures/
4+
/gradlew
5+
/gradlew.bat
6+
/local.properties
7+
GeneratedPluginRegistrant.java
8+
9+
# Remember to never publicly share your keystore.
10+
# See https://flutter.dev/to/reference-keystore
11+
key.properties
12+
**/*.keystore
13+
**/*.jks

android/app/build.gradle

Lines changed: 44 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,44 @@
1+
plugins {
2+
id "com.android.application"
3+
id "kotlin-android"
4+
// The Flutter Gradle Plugin must be applied after the Android and Kotlin Gradle plugins.
5+
id "dev.flutter.flutter-gradle-plugin"
6+
}
7+
8+
android {
9+
namespace = "com.example.import_excel"
10+
compileSdk = flutter.compileSdkVersion
11+
ndkVersion = flutter.ndkVersion
12+
13+
compileOptions {
14+
sourceCompatibility = JavaVersion.VERSION_1_8
15+
targetCompatibility = JavaVersion.VERSION_1_8
16+
}
17+
18+
kotlinOptions {
19+
jvmTarget = JavaVersion.VERSION_1_8
20+
}
21+
22+
defaultConfig {
23+
// TODO: Specify your own unique Application ID (https://developer.android.com/studio/build/application-id.html).
24+
applicationId = "com.example.import_excel"
25+
// You can update the following values to match your application needs.
26+
// For more information, see: https://flutter.dev/to/review-gradle-config.
27+
minSdk = flutter.minSdkVersion
28+
targetSdk = flutter.targetSdkVersion
29+
versionCode = flutter.versionCode
30+
versionName = flutter.versionName
31+
}
32+
33+
buildTypes {
34+
release {
35+
// TODO: Add your own signing config for the release build.
36+
// Signing with the debug keys for now, so `flutter run --release` works.
37+
signingConfig = signingConfigs.debug
38+
}
39+
}
40+
}
41+
42+
flutter {
43+
source = "../.."
44+
}
Lines changed: 7 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,7 @@
1+
<manifest xmlns:android="http://schemas.android.com/apk/res/android">
2+
<!-- The INTERNET permission is required for development. Specifically,
3+
the Flutter tool needs it to communicate with the running application
4+
to allow setting breakpoints, to provide hot reload, etc.
5+
-->
6+
<uses-permission android:name="android.permission.INTERNET"/>
7+
</manifest>
Lines changed: 45 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,45 @@
1+
<manifest xmlns:android="http://schemas.android.com/apk/res/android">
2+
<application
3+
android:label="import_excel"
4+
android:name="${applicationName}"
5+
android:icon="@mipmap/ic_launcher">
6+
<activity
7+
android:name=".MainActivity"
8+
android:exported="true"
9+
android:launchMode="singleTop"
10+
android:taskAffinity=""
11+
android:theme="@style/LaunchTheme"
12+
android:configChanges="orientation|keyboardHidden|keyboard|screenSize|smallestScreenSize|locale|layoutDirection|fontScale|screenLayout|density|uiMode"
13+
android:hardwareAccelerated="true"
14+
android:windowSoftInputMode="adjustResize">
15+
<!-- Specifies an Android theme to apply to this Activity as soon as
16+
the Android process has started. This theme is visible to the user
17+
while the Flutter UI initializes. After that, this theme continues
18+
to determine the Window background behind the Flutter UI. -->
19+
<meta-data
20+
android:name="io.flutter.embedding.android.NormalTheme"
21+
android:resource="@style/NormalTheme"
22+
/>
23+
<intent-filter>
24+
<action android:name="android.intent.action.MAIN"/>
25+
<category android:name="android.intent.category.LAUNCHER"/>
26+
</intent-filter>
27+
</activity>
28+
<!-- Don't delete the meta-data below.
29+
This is used by the Flutter tool to generate GeneratedPluginRegistrant.java -->
30+
<meta-data
31+
android:name="flutterEmbedding"
32+
android:value="2" />
33+
</application>
34+
<!-- Required to query activities that can process text, see:
35+
https://developer.android.com/training/package-visibility and
36+
https://developer.android.com/reference/android/content/Intent#ACTION_PROCESS_TEXT.
37+
38+
In particular, this is used by the Flutter engine in io.flutter.plugin.text.ProcessTextPlugin. -->
39+
<queries>
40+
<intent>
41+
<action android:name="android.intent.action.PROCESS_TEXT"/>
42+
<data android:mimeType="text/plain"/>
43+
</intent>
44+
</queries>
45+
</manifest>
Lines changed: 5 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,5 @@
1+
package com.example.import_excel
2+
3+
import io.flutter.embedding.android.FlutterActivity
4+
5+
class MainActivity: FlutterActivity()
Lines changed: 12 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,12 @@
1+
<?xml version="1.0" encoding="utf-8"?>
2+
<!-- Modify this file to customize your launch splash screen -->
3+
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
4+
<item android:drawable="?android:colorBackground" />
5+
6+
<!-- You can insert your own image assets here -->
7+
<!-- <item>
8+
<bitmap
9+
android:gravity="center"
10+
android:src="@mipmap/launch_image" />
11+
</item> -->
12+
</layer-list>
Lines changed: 12 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,12 @@
1+
<?xml version="1.0" encoding="utf-8"?>
2+
<!-- Modify this file to customize your launch splash screen -->
3+
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
4+
<item android:drawable="@android:color/white" />
5+
6+
<!-- You can insert your own image assets here -->
7+
<!-- <item>
8+
<bitmap
9+
android:gravity="center"
10+
android:src="@mipmap/launch_image" />
11+
</item> -->
12+
</layer-list>
544 Bytes
Loading

0 commit comments

Comments
 (0)