文件分享(使用Content URI)

本文介绍了如何在Android应用中使用Content URI实现文件分享功能。首先在manifest文件中声明FileProvider,接着在xml资源文件中定义可分享的文件夹路径,包括files目录、外部存储和缓存目录。然后,设计一个文件选择界面,通过ACTION_PICK和CATEGORY_DEFAULT等设置,允许用户选择并分享特定类型的文件。
摘要由CSDN通过智能技术生成

一、在manifest文件中声明FileProvider,如:

<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.example.myapp">
    <application
        ...>
        <provider
            android:name="android.support.v4.content.FileProvider"
            android:authorities="com.example.myapp.fileprovider"
            android:grantUriPermissions="true"
            android:exported="false">
            <meta-data
                android:name="android.support.FILE_PROVIDER_PATHS"
                android:resource="@xml/filepaths" />
        </provider>
        ...
    </application>
</manifest>

authorities属性指明FileProvider为content URI产生的URI域名部分,meta-data下的resource则指明你要分享的文件夹。


二、指明可分享的文件夹
在res文件夹下新建xml文件夹,在xml文件夹下新建resource属性指明的filepaths.xml文件,在其中声明可分享的文件夹,如:

<paths>
    <files-path path="images/" name="myimages" />
</paths>

<paths>标签可以有多个子节点,每个子节点指明了一个分享的文件夹;
<file-path>标签指示要分享的文件夹位于你的app的内存的files目录下,path属性表明一个子文件夹,name属性添加对应的路径到content URI;
<external-path>标签指示要分享的文件位于外部存储的文件夹;
<cache-path>标签指示要分享的文件位于app的缓存文件夹下。


三.设计一个文件选择的界面
在manifest文件中声明该界面,action为ACTION_PICK,category为CATEGORY_DEFAULT和CATEGORY_OPENABLE,也可以声明你的app可以分享的文件类型,如:
<

要在Android中解析URI路径的Excel文件,您可以使用Apache POI库。以下是一个简单的示例代码,演示如何使用Apache POI解析Excel文件: ```java import android.content.ContentResolver; import android.content.Context; import android.database.Cursor; import android.net.Uri; import android.provider.OpenableColumns; import androidx.annotation.NonNull; import androidx.annotation.Nullable; import androidx.appcompat.app.AppCompatActivity; import android.os.Bundle; import android.util.Log; import android.widget.Toast; import org.apache.poi.ss.usermodel.Cell; import org.apache.poi.ss.usermodel.Row; import org.apache.poi.ss.usermodel.Sheet; import org.apache.poi.ss.usermodel.Workbook; import org.apache.poi.ss.usermodel.WorkbookFactory; import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.IOException; import java.io.InputStream; public class MainActivity extends AppCompatActivity { private static final String TAG = "ExcelParsing"; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); // 假设您已经有一个URI路径,这是从系统分享中获取的 Uri fileUri = getIntent().getData(); // 解析Excel文件 parseExcelFile(this, fileUri); } private void parseExcelFile(Context context, Uri fileUri) { try { InputStream inputStream = context.getContentResolver().openInputStream(fileUri); // 使用WorkbookFactory打开Excel文件 Workbook workbook = WorkbookFactory.create(inputStream); // 获取第一个Sheet Sheet sheet = workbook.getSheetAt(0); // 遍历行 for (Row row : sheet) { // 遍历单元格 for (Cell cell : row) { // 获取单元格值并打印 String cellValue = cell.toString(); Log.d(TAG, "Cell value: " + cellValue); } } // 关闭输入流和工作簿 inputStream.close(); workbook.close(); } catch (FileNotFoundException e) { e.printStackTrace(); Toast.makeText(context, "File not found!", Toast.LENGTH_SHORT).show(); } catch (IOException e) { e.printStackTrace(); Toast.makeText(context, "Error reading file!", Toast.LENGTH_SHORT).show(); } } } ``` 这段代码会打开URI路径指向的Excel文件,并使用Apache POI库解析文件内容。请确保您的应用程序已添加Apache POI库的依赖项。您可以在build.gradle文件中的dependencies部分添加以下行来添加依赖项: ```groovy implementation 'org.apache.poi:poi:4.1.2' implementation 'org.apache.poi:poi-ooxml:4.1.2' ``` 请注意,此示例仅用于演示目的。您可能需要根据实际需求进行适当的异常处理和数据处理。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值