文件读取和写入:打开本地管理器选择txt

本文档详细介绍了如何使用文件管理器选择本地txt文件,进行读取和写入操作。首先,需要声明内存读取权限,并动态请求该权限。接着,通过读取txt文本内容,对其进行格式化处理后展示在界面上。同时,教程中还涵盖了如何保存内容到新的txt副本,确保使用utf-8编码以避免乱码问题。最后,将展示如何打开文件管理器并获取用户选定的txt文件。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

拓展:文件管理工具类—FileUtil 实现的功能:获得外部存储绝对路径、创建文件夹、创建文件、遍历文件夹下的所有文件、获得指定文件、删除文件夹里的所有文件、删除文件、向文件中的指定位置添加String内容、修改文件内容(覆盖或者添加String)、读取文件内容String、重命名文件、复制文件夹、复制文件、拷贝图片文件、修改文件内容String(相对路径)。。。

一、功能描述

打开文件管理器,选择本地txt,按行读取内容,按一定格式整理每行内容,显示在界面上,并保存副本txt在同一个文件夹里。
注意:
1.请把txt保存格式修改为utf-8,否则文本会乱码(打开文件,另存为,修改保存格式)
2.动态申请写入权限!!!

二、运行效果

在这里插入图片描述

三、技术点讲解

1、声明内存读取权限

 <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />
 <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />

2、动态请求内存读取权限

 private String[] permissions = {Manifest.permission.READ_EXTERNAL_STORAGE, Manifest.permission.WRITE_EXTERNAL_STORAGE};
  /**
     * 开始提交请求权限
     */
    private void startRequestPermission() {
        ActivityCompat.requestPermissions(MainActivity.this, permissions, RESULT_SUCCESS);
    }

    /**
     * 用户权限 申请 的回调方法
     *
     * @param requestCode
     * @param permissions
     * @param grantResults
     */
    @Override
    public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
        super.onRequestPermissionsResult(requestCode, permissions, grantResults);
        if (requestCode == RESULT_SUCCESS) {
            if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {
                if (grantResults[0] == PackageManager.PERMISSION_GRANTED) {
                    isGetPermission = true;
                }
            } else {
                isGetPermission = true;
            }
        }
        if (!isGetPermission) {
            llMain.setVisibility(View.GONE);
        } else {
            llMain.setVisibility(View.VISIBLE);
        }
    }

3、读

### 关于 Cursor 安装过程中无法写入文件的问题 当遇到 `cursor` 安装过程中的文件写入失败问题时,通常这并不是由 `cursor` 自身引起的,而是由于底层数据库驱动或其他环境因素造成的。以下是几种常见的原因及其对应的解决方案: #### 数据库连接配置错误 如果使用的数据库客户端(如 MySQL 或 PostgreSQL 的 Python 库)未能正确初始化,则可能导致操作受限或异常终止。对于MySQL而言,在尝试读取 BLOB 类型的数据并将其保存到本地磁盘的过程中出现问题可能是由于缺少必要的权限或是路径设置不正确所引起[^1]。 #### 缺少必要依赖包 某些情况下,特定功能模块缺失也会引发此类现象。例如,在使用PostgreSQL时,如果没有预先通过pip安装psycopg2这个官方推荐的适配的话,程序会抛出ImportError提示用户去执行相应的命令来获取该组件[^2]。 ```bash pip install psycopg2-binary ``` 上述指令可以帮助快速解决问题;不过需要注意的是长期项目建议采用源码编译版而非binary版本以获得更好的兼容性性能表现。 #### 文件编码与操作系统差异 针对不同平台间存在的字符集转换难题,尤其是在处理包含非ASCII字符的内容时尤为明显。Windows环境下,默认采用GBK作为内部表示方式之一,因此即使应用程序指定了UTF-8也未必能完全避免潜在冲突。对此类情况的一个有效对策就是统一整个工作流内的文字编码标准至GB系列,并确保所有涉及文本传输的地方均遵循这一原则[^3]。 #### 大数据量处理策略调整 另外值得注意的一点是在面对非常庞大的单条记录或者批量导入场景下,部分中间件可能会因为消息尺寸超出预设阈值而拒绝接收/发送请求。比如Canal同步工具就存在这样的限制条件,此时可以通过配置项canal.instance.filter.black.field 来排除那些不必要的大型字段从而减轻负担[^4]。 综上所述,解决Cursor安装期间发生的文件写入障碍需综合考量以上各方面要素,并针对性采取措施加以优化改进。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值