Я делаю проект для чтения файлов Excel с моего телефона и вывода данных на экран.
Вот как я пытаюсь это сделать:
private fun readDataExel() {
val file = Uri.parse("content://com.android.providers.media.documents/document/document%3A1000007061")
val inputStream = getContentResolver().openInputStream(file)
//Instantiate Excel workbook using existing file:
val workbook = WorkbookFactory.create(inputStream)
//Get reference to first sheet:
val sheet = workbook.getSheet("list")
for (row in sheet) {
if (row.getCell(0) == null || row.getCell(0).cellType == CellType.BLANK) {
break
}
val codeValue = row.getCell(0).stringCellValue.toString()
val liteCodeValue = codeValue.replace(".", "").replace("-", "")
val articleValue = row.getCell(1).stringCellValue.toString()
articles.add(ArticleModel(
code = codeValue,
liteCode = liteCodeValue,
title = articleValue
))
}
< /code>
Я получаю ошибку, когда пытаюсь преобразовать URI в inputstream.FATAL EXCEPTION: main
Process: com.scan.scanforphonekarcher, PID: 13375java.lang.RuntimeException: Unable to start activity
ComponentInfo{com.scan.scanforphonekarcher/com.scan.scanforphonekarcher.MainActivity}: java.lang.SecurityException: Permission Denial: opening provider com.android.providers.media.MediaDocumentsProvider from ProcessRecord{dd2bdda 13375:com.scan.scanforphonekarcher/u0a477} (pid=13375, uid=10477) requires that you obtain access using ACTION_OPEN_DOCUMENT or related APIs
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:4169)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:4325)
at android.app.servertransaction.LaunchActivityItem.execute(LaunchActivityItem.java:101)
at android.app.servertransaction.TransactionExecutor.executeCallbacks(TransactionExecutor.java:135)
at android.app.servertransaction.TransactionExecutor.execute(TransactionExecutor.java:95)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2574)
at android.os.Handler.dispatchMessage(Handler.java:106)
at android.os.Looper.loopOnce(Looper.java:226)
at android.os.Looper.loop(Looper.java:313)
at android.app.ActivityThread.main(ActivityThread.java:8762)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:604)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1067)
Caused by: java.lang.SecurityException: Permission Denial: opening provider com.android.providers.media.MediaDocumentsProvider from ProcessRecord{dd2bdda 13375:com.scan.scanforphonekarcher/u0a477} (pid=13375, uid=10477) requires that you obtain access using ACTION_OPEN_DOCUMENT or related APIs
at android.os.Parcel.createExceptionOrNull(Parcel.java:3023)
at android.os.Parcel.createException(Parcel.java:3007)
at android.os.Parcel.readException(Parcel.java:2990)
at android.os.Parcel.readException(Parcel.java:2932)
at android.app.IActivityManager$Stub$Proxy.getContentProvider(IActivityManager.java:6136)
at android.app.ActivityThread.acquireProvider(ActivityThread.java:7867)
...
< /code>
Я пытаюсь получить файл ecxel (.xlsx) из моего телефона и прочитать данные из файла. < /p>
Я Googled Много и смотрел видео на YouTube, но я не нашел решение моей проблемы.
Спасибо за помощь
Подробнее здесь: https://stackoverflow.com/questions/794 ... nputstream
Android Kotlin uri в inputstream ⇐ Android
Форум для тех, кто программирует под Android
1739934207
Anonymous
Я делаю проект для чтения файлов Excel с моего телефона и вывода данных на экран.
Вот как я пытаюсь это сделать:
private fun readDataExel() {
val file = Uri.parse("content://com.android.providers.media.documents/document/document%3A1000007061")
val inputStream = getContentResolver().openInputStream(file)
//Instantiate Excel workbook using existing file:
val workbook = WorkbookFactory.create(inputStream)
//Get reference to first sheet:
val sheet = workbook.getSheet("list")
for (row in sheet) {
if (row.getCell(0) == null || row.getCell(0).cellType == CellType.BLANK) {
break
}
val codeValue = row.getCell(0).stringCellValue.toString()
val liteCodeValue = codeValue.replace(".", "").replace("-", "")
val articleValue = row.getCell(1).stringCellValue.toString()
articles.add(ArticleModel(
code = codeValue,
liteCode = liteCodeValue,
title = articleValue
))
}
< /code>
Я получаю ошибку, когда пытаюсь преобразовать URI в inputstream.FATAL EXCEPTION: main
Process: com.scan.scanforphonekarcher, PID: 13375java.lang.RuntimeException: Unable to start activity
ComponentInfo{com.scan.scanforphonekarcher/com.scan.scanforphonekarcher.MainActivity}: java.lang.SecurityException: Permission Denial: opening provider com.android.providers.media.MediaDocumentsProvider from ProcessRecord{dd2bdda 13375:com.scan.scanforphonekarcher/u0a477} (pid=13375, uid=10477) requires that you obtain access using ACTION_OPEN_DOCUMENT or related APIs
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:4169)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:4325)
at android.app.servertransaction.LaunchActivityItem.execute(LaunchActivityItem.java:101)
at android.app.servertransaction.TransactionExecutor.executeCallbacks(TransactionExecutor.java:135)
at android.app.servertransaction.TransactionExecutor.execute(TransactionExecutor.java:95)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2574)
at android.os.Handler.dispatchMessage(Handler.java:106)
at android.os.Looper.loopOnce(Looper.java:226)
at android.os.Looper.loop(Looper.java:313)
at android.app.ActivityThread.main(ActivityThread.java:8762)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:604)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1067)
Caused by: java.lang.SecurityException: Permission Denial: opening provider com.android.providers.media.MediaDocumentsProvider from ProcessRecord{dd2bdda 13375:com.scan.scanforphonekarcher/u0a477} (pid=13375, uid=10477) requires that you obtain access using ACTION_OPEN_DOCUMENT or related APIs
at android.os.Parcel.createExceptionOrNull(Parcel.java:3023)
at android.os.Parcel.createException(Parcel.java:3007)
at android.os.Parcel.readException(Parcel.java:2990)
at android.os.Parcel.readException(Parcel.java:2932)
at android.app.IActivityManager$Stub$Proxy.getContentProvider(IActivityManager.java:6136)
at android.app.ActivityThread.acquireProvider(ActivityThread.java:7867)
...
< /code>
Я пытаюсь получить файл ecxel (.xlsx) из моего телефона и прочитать данные из файла. < /p>
Я Googled Много и смотрел видео на YouTube, но я не нашел решение моей проблемы.
Спасибо за помощь
Подробнее здесь: [url]https://stackoverflow.com/questions/79439817/android-kotlin-uri-to-inputstream[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия