запись в текстовый файл в андроиде

Я пробовал код от MallikarjunM , но у меня это не работает :-(. Я его немного переписываю в свой базовый проект Android Studio с пустой активностью с одним textViev "pokusnejText".

вот мой код MainActivity.kt:

package com.example.zapisdosouboru

import android.support.v7.app.AppCompatActivity
import android.os.Bundle
import android.os.Environment
import android.widget.TextView
import java.io.File
import java.io.PrintWriter

class MainActivity : AppCompatActivity() {

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)

        val pokusnejText = findViewById<TextView>(R.id.pokusnejText)


        var answer : String = ""
        val sd_main = File(Environment.getExternalStorageDirectory().toString() + "/smazat" )
        var success = true
        if (!sd_main.exists()) {
            success = sd_main.mkdir()
            if (success) {
                answer = "folder created"
            } else {
                answer = "folder can not be created"
            }
        }

        if (success) {
            val sd = File("testingFile.txt")

            if (!sd.exists()) {
                success = sd.mkdir()
            }

            if (success) {
                // directory exists or already created
                val dest = File(sd, "testingFile.txt")

                try {
                    // response is the data written to file
                    PrintWriter(dest).use { out -> out.println(answer) }
                    answer = "writed to" + sd.toString()
                } catch (e: Exception) {
                    answer = "can not be written"
                }

            } else {
                answer = "folder or file does not exists"
            }
        }
        pokusnejText.text = answer
    }
}

и вот мой AndroidManifest.xml:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
          package="com.example.zapisdosouboru">
    <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
    <application
            android:allowBackup="true"
            android:icon="@mipmap/ic_launcher"
            android:label="@string/app_name"
            android:roundIcon="@mipmap/ic_launcher_round"
            android:supportsRtl="true"
            android:theme="@style/AppTheme">
        <activity android:name=".MainActivity">
            <intent-filter>
                <action android:name="android.intent.action.MAIN"/>

                <category android:name="android.intent.category.LAUNCHER"/>
            </intent-filter>
        </activity>

    </application>

</manifest>

первое, что я переписал, было

val sd_main = File(Environment.getExternalStorageDirectory()+"/yourlocation")

to

val sd_main = File(Environment.getExternalStorageDirectory().toString() + "/yourlocation" )

потому что без toString() был плюс отмечен красным ... но он все еще не работает и отвечает, что не может создать папку ... Я пробовал это в эмуляторе Android Studio с Android 6.0

Некоторые дополнительные вопросы: меня очень смущает функция File(), используемая в коде один раз с одним параметром и второй раз с двумя. Существует ли для Kotlin веб-страница, похожая на http://www.cplusplus.com/ - я не могу найти любой такой полезный, как для С++.

Спасибо за помощь fik236


person fik236    schedule 14.04.2019    source источник


Ответы (2)


Вы говорите, что пробовали это на эмуляторе Android 6. Вы явно запрашивали WRITE_EXTERNAL_STORAGE разрешение перед записью во внешнее хранилище? Что выводится в логарифме при выполнении этого кода? Там должно быть написано, что он не может создать файл из-за «отказано в доступе»

Что касается сайта, похожего на cplusplus.com, конечно, есть справочник по языку Kotlin, который выполняет ту же функцию, что и cpp.com, и я бы сказал, что он даже лучше, так как содержит ссылки на книги, онлайн-курсы и т. д.

person Maroš Šeleng    schedule 14.04.2019
comment
Спасибо за ответ. Я думал, что у меня есть доступ к расширенному хранилищу с четвертой строкой моего AndroidManifest.xml (моя вторая часть кода в запросе). Мой logcat теперь пуст. Я не знаю, есть ли у меня что-то поврежденное, потому что у меня есть кнопка корзины (очистить logcat) для облегчения поиска. Были какие-то сообщения - но сейчас пусто. - person fik236; 14.04.2019
comment
Вы внимательно прочитали первую ссылку, которую я дал? в нем говорится, что вы объявляете, что вашему приложению требуется разрешение, перечисляя разрешение в манифесте приложения, а затем запрашивая, чтобы пользователь одобрил каждое разрешение во время выполнения (на Android 6.0 и выше). Вам необходимо запросить соответствующее разрешение динамически во время выполнения. Пожалуйста, прочтите прикрепленную статью, чтобы узнать, как обрабатывать запросы разрешений во время выполнения. - person Maroš Šeleng; 15.04.2019

благодаря Maroš Šeleng у меня есть кое-какой рабочий код. Вот:

package com.example.zapisdosouboru

import android.Manifest
import android.content.pm.PackageManager
import android.support.v7.app.AppCompatActivity
import android.os.Bundle
import android.os.Environment
import android.support.v4.app.ActivityCompat
import android.widget.TextView
import java.io.File
import java.io.PrintWriter

class MainActivity : AppCompatActivity() {

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)



        // Here, thisActivity is the current activity
        if (checkSelfPermission( Manifest.permission.WRITE_EXTERNAL_STORAGE) != PackageManager.PERMISSION_GRANTED) {

            // Permission is not granted
            // Should we show an explanation?
            if (ActivityCompat.shouldShowRequestPermissionRationale(this, Manifest.permission.WRITE_EXTERNAL_STORAGE)) {
                // Show an explanation to the user *asynchronously* -- don't block
                // this thread waiting for the user's response! After the user
                // sees the explanation, try again to request the permission.
            } else {
                // No explanation needed, we can request the permission.
                ActivityCompat.requestPermissions(this, arrayOf(Manifest.permission.WRITE_EXTERNAL_STORAGE), 1)

                // MY_PERMISSIONS_REQUEST_READ_CONTACTS is an
                // app-defined int constant. The callback method gets the
                // result of the request.
            }
        } else {
            // Permission has already been granted
        }

        val pokusnejText = findViewById<TextView>(R.id.pokusnejText)


        var answer : String = ""
        val sd_main = File(Environment.getExternalStorageDirectory() , "smazat" )
        var success = true
        if (!sd_main.exists()) {
            success = sd_main.mkdir()
            if (success) {
                answer = "folder created"
            } else {
                answer = "folder can not be created"
            }
        }

        if (success) {
            val sd = File(sd_main,"testingFile.txt")

            if (!sd.isFile()) {
                success = sd.createNewFile()
            }

            if (success) {
                // directory exists or already created

                try {
                    answer = "writed to" + sd.toString()
                    PrintWriter(sd).use { out -> out.println("testing text") }

                } catch (e: Exception) {
                    answer = "can not be written"
                }

            } else {
                answer = "folder or file does not exists"
            }
        }
        pokusnejText.text = answer
    }
}
person fik236    schedule 16.04.2019