スポンサーリンク

【Flutter】アプリ内部ストレージのファイル一覧を取得する方法。

Flutter
スポンサーリンク

今回の記事はFlutterでアプリ内の内部ストレージ以下のファイル一覧を取得する方法に関して記載します。

スポンサーリンク

Flutterで内部ストレージを作成

内部ストレージを作成するために必要なライブラリのインポートを行います。

dependencies:
  path_provider: ^1.6.27
  flutter:
    sdk: flutter

Flutterでアプリ内にファイルを作成する

Future<void> maketxt_showlist() async{
    //ログファイル作成
    final logDirectory = await getApplicationDocumentsDirectory();
    String logPath = '${logDirectory.path}/test.txt';
    File textfilePath = File(logPath);
    await textfilePath.writeAsString('test');
}

Flutterのファイル一覧を取得する

では上記のテキストファイルを作成する方法を踏まえてその作成したファイルを確認するアプリを作成します。基本的にFlutterの初期プロジェクトを少しいじった程度のアプリになります。

import 'dart:io';

import 'package:flutter/material.dart';
import 'package:path_provider/path_provider.dart';


void main() {
  runApp(MyApp());
}

class MyApp extends StatelessWidget {
  // This widget is the root of your application.
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Flutter Demo',
      theme: ThemeData(

        primarySwatch: Colors.blue,

        visualDensity: VisualDensity.adaptivePlatformDensity,
      ),
      home: MyHomePage(title: 'Flutter Demo Home Page'),
    );
  }
}

class MyHomePage extends StatefulWidget {
  MyHomePage({Key key, this.title}) : super(key: key);

  final String title;

  @override
  _MyHomePageState createState() => _MyHomePageState();
}

class _MyHomePageState extends State<MyHomePage> {
  int _counter = 0;

  Future<void> maketxt_showlist() async{
    //ログファイル作成
    final logDirectory = await getApplicationDocumentsDirectory();
    String logPath = '${logDirectory.path}/test.txt';
    File textfilePath = File(logPath);
    await textfilePath.writeAsString('test');

    List<FileSystemEntity> files;
    files = logDirectory.listSync(recursive: true,followLinks: false);
    for (var file in files) {
      print(file);
    }
  }

  @override
  Widget build(BuildContext context) {

    return Scaffold(
      appBar: AppBar(

        title: Text(widget.title),
      ),
      body: Center(

        child: Column(

          mainAxisAlignment: MainAxisAlignment.center,
          children: <Widget>[
            Text(
              'You have pushed the button this many times:',
            ),
            Text(
              '$_counter',
              style: Theme.of(context).textTheme.headline4,
            ),
          ],
        ),
      ),
      floatingActionButton: FloatingActionButton(
        onPressed: maketxt_showlist,
        tooltip: 'Increment',
        child: Icon(Icons.add),
      ), // This trailing comma makes auto-formatting nicer for build methods.
    );
  }
}

少し解説していきます。

  Future<void> maketxt_showlist() async{
    //ログファイル作成
    final logDirectory = await getApplicationDocumentsDirectory();
    String logPath = '${logDirectory.path}/test.txt';
    File textfilePath = File(logPath);
    await textfilePath.writeAsString('test');

    List<FileSystemEntity> files;
    files = logDirectory.listSync(recursive: true,followLinks: false);
    for (var file in files) {
      print(file);
    }
  }

上部分がファイル作成を行う部分で、下部分の「listSync(recursive: true,followLinks: false)」が内部ストレージのファイル一覧を取得している部分です。

今回の記事は以上です。他にもFlutterの記事を書いておりますので気になる方はご参照ください。

本記事を読んでいただき感謝です。サイトを訪れていただいた方はプログラミング勉強中かと思いますのでプログラミング勉強のコツを合わせてご紹介。

スポンサーリンク
スポンサーリンク
スポンサーリンク

ブログに関しては500円程度かかりますが、それ以外は無料です。知識の吸収と並行してアウトプットは非常に効率が良いです。テックアカデミーに関しては講座レベルが高いにも関わらず、無料体験や人気口座も大幅値下げがあるので、重点的に学びたいものを無料体験してみてください。

転職時にも、エンジニアからテックアカデミー・Paizaは認知度が高いので、未経験入社採用を行う際履歴書で目に留まります。特にPaizaのスキルレベルA・SなどはIT業界でも評価されます。

テックアカデミー・Paizaの無料登録ができる期間中にぜひご利用してみてください。私も活用経験ありです。

Flutter
スポンサーリンク
スポンサーリンク

コメント

タイトルとURLをコピーしました