Ошибки при записи строки в текстовый файл - PullRequest
2 голосов
/ 06 мая 2020

Я пытался записать строку в текстовый файл во флаттере нажатием кнопки. Вот мой код:

onPressed: () async {
                        File('dates.txt').writeAsStringSync('${_date.month}/${_date.day}/${_date.year}');
                      }),

Я не знаю, почему он не работает, я думаю, что мне что-то не хватает. Спасибо за уделенное время!

1 Ответ

0 голосов
/ 06 мая 2020

Я нашел решение этой проблемы. Подводя итог, я просмотрел страницу в документации Flutter (https://flutter.dev/docs/cookbook/persistence/reading-writing-files) и обнаружил, что мне просто нужно добавить некоторые фьючерсы, которые были необходимы для чтения / записи файлов, и применил их к моей функции "onPressed". .

Вот мой последний код:

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

void main() => runApp(MaterialApp(
      home: FirstScreen(),
    ));

class FirstScreen extends StatelessWidget {
  @override
  Widget build(BuildContext ctxt) {
    return new Scaffold(
      appBar: new AppBar(
        centerTitle: true,
        title: new Text("My School Calendar"),
      ),
      body: Container(
          child: Align(
        alignment: Alignment(0, -0.9),
        child: FlatButton.icon(
          color: Colors.teal,
          icon: Icon(Icons.plus_one), //`Icon` to display
          label: Text('Create new entry'), //`Text` to display
          onPressed: () {
            Navigator.push(
              ctxt,
              new MaterialPageRoute(builder: (ctxt) => new SecondScreen()),
            );
          },
        ),
      )),
    );
  }
}

class SecondScreen extends StatefulWidget {
  @override
  _SecondScreenState createState() => _SecondScreenState();
}

class _SecondScreenState extends State<SecondScreen> {
  DateTime _date = new DateTime.now();
  TimeOfDay _time = new TimeOfDay.now();

  Future<Null> _selectDate(BuildContext ctxt) async {
    final DateTime picked = await showDatePicker(
      context: ctxt,
      initialDate: _date,
      firstDate: new DateTime.now().subtract(Duration(days: 1)),
      lastDate: new DateTime.now().add(Duration(days: 365)),
    );
    if (picked != null && picked != _date) {
      print('Date selected: ${_date.toString()}');
      setState((){
        _date = picked;
      });
    }
  }

  Future<Null> _selectTime(BuildContext ctxt) async {
    final TimeOfDay picked = await showTimePicker(
        context: ctxt,
        initialTime: _time
    );
    if (picked != null && picked != _time) {
      print('Date selected: ${_time.toString()}');
      setState((){
        _time = picked;
      });
    }
  }

  Future<File> get _localFile async {
    final path = await _localPath;
    return File('$path/date.txt');
  }
  Future<String> get _localPath async {
    final directory = await getApplicationDocumentsDirectory();

    return directory.path;
  }

  Future<int> readDate() async {
    try {
      final file = await _localFile;

      // Read the file
      String contents = await file.readAsString();
      print('Date read from file: ' + contents);
    } catch (e) {
      // If encountering an error, return 0
      return 0;
    }
  }

  Future<File> writeDate() async {
    final file = await _localFile;

    // Write the file.
    String dateToWrite = '${_date.month}/${_date.day}/${_date.year}';
    return file.writeAsString(dateToWrite);
  }

  final myController = TextEditingController();
  @override
  Widget build(BuildContext ctxt) {
    return MaterialApp(
        home: Scaffold(
            appBar: new AppBar(
              title: new Text("Enter assignment details"),
            ),
            body: Container(
              margin: const EdgeInsets.only(top: 10.0),
              child: Align(
                alignment: Alignment(0, -0.9),
                child: Column(children: <Widget>[
                  TextField(
                    controller: myController,
                    textAlign: TextAlign.center,
                    decoration: InputDecoration(
                        border: OutlineInputBorder(
                          borderSide: BorderSide(
                            color: Colors.black,
                          ),
                          borderRadius: BorderRadius.all(Radius.circular(15)),
                        ),
                        hintText: 'Enter assignment name'),
                  ),
                  FlatButton.icon(
                      color: Colors.redAccent,
                      icon: Icon(Icons.calendar_today), //`Icon` to display
                      label: Text('Select date'), //`Text` to display
                      onPressed: () {
                        _selectDate(ctxt);
                      }),
                  Text('Date selected: ${_date.month}/${_date.day}/${_date.year}'),
                  FlatButton.icon(
                      color: Colors.grey,
                      icon: Icon(Icons.access_time), //`Icon` to display
                      label: Text('Select time'), //`Text` to display
                      onPressed: () {
                        _selectTime(ctxt);
                      }),
                  Text('Time selected: ${_time.hour}:${_time.minute}'),
                  FlatButton.icon(
                      color: Colors.lightBlueAccent,
                      icon: Icon(Icons.check_box), //`Icon` to display
                      label: Text('Submit'), //`Text` to display
                      onPressed: () {
                        writeDate();
                        readDate();
                      }),
                ]),
              ),
            )));
  }
}

Надеюсь, это помогло другим!

...