前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Android制作字符串表格String.xml转EXCEL工具

Android制作字符串表格String.xml转EXCEL工具

作者头像
全栈程序员站长
发布2022-09-23 10:07:41
8820
发布2022-09-23 10:07:41
举报
文章被收录于专栏:全栈程序员必看

大家好,又见面了,我是你们的朋友全栈君

代码语言:javascript
复制
public static List<String> getAllExternalSdcardPath() {
        List<String> PathList = new ArrayList<String>();

        String firstPath = Environment.getExternalStorageDirectory().getPath();
        Log.d(TAG,"getAllExternalSdcardPath , firstPath = "+firstPath);

        try {
        // 运行mount命令,获取命令的输出,得到系统中挂载的所有目录
            Runtime runtime = Runtime.getRuntime();
            Process proc = runtime.exec("mount");
            InputStream is = proc.getInputStream();
            InputStreamReader isr = new InputStreamReader(is);
            String line;
            BufferedReader br = new BufferedReader(isr);
            while ((line = br.readLine()) != null) {
                // 将常见的linux分区过滤掉
                if (line.contains("proc") || line.contains("tmpfs") || line.contains("media") || line.contains("asec") || line.contains("secure") || line.contains("system") || line.contains("cache")
                        || line.contains("sys") || line.contains("data") || line.contains("shell") || line.contains("root") || line.contains("acct") || line.contains("misc") || line.contains("obb")) {
                    continue;
                }

                // 下面这些分区是我们需要的
                if (line.contains("fat") || line.contains("fuse") || (line.contains("ntfs"))){
                    // 将mount命令获取的列表分割,items[0]为设备名,items[1]为挂载路径
                    String items[] = line.split(" ");
                    if (items != null && items.length > 1){
                        String path = items[1].toLowerCase(Locale.getDefault());
                        // 添加一些判断,确保是sd卡,如果是otg等挂载方式,可以具体分析并添加判断条件
                        if (path != null && !PathList.contains(path) && path.contains("sd"))
                            PathList.add(items[1]);
                    }
                }
            }
        } catch (Exception e){
            // TODO Auto-generated catch block
            e.printStackTrace();
        }

        if (!PathList.contains(firstPath)) {
            PathList.add(firstPath);
        }

        return PathList;
    }

想将Android应用中的多国语言翻译整理成一张excel表格来进行维护,或者校对,或者是给客户发一个语言对照说明表?一个个手动复制粘贴?那太LOW了吧,没有什么重复动作是一个程序员不能编程实现的,现在就上一个转换工具,可以将String.xml转换的EXCEL的.xls。当然也能将EXCEL直接转换成String.XML。废话不多说,直接上源码实例。

当然最要注意的是,你首先需要确定你的sd卡路径或者usb的路径。然后稍微改动代码中的路径就可以让你想放哪里就放哪里了。

也可以使用这个方法获取路径:

public static List<String> getAllExternalSdcardPath() { List<String> PathList = new ArrayList<String>();

String firstPath = Environment.getExternalStorageDirectory().getPath(); Log.d(TAG,”getAllExternalSdcardPath , firstPath = “+firstPath);

try { // 运行mount命令,获取命令的输出,得到系统中挂载的所有目录 Runtime runtime = Runtime.getRuntime(); Process proc = runtime.exec(“mount”); InputStream is = proc.getInputStream(); InputStreamReader isr = new InputStreamReader(is); String line; BufferedReader br = new BufferedReader(isr); while ((line = br.readLine()) != null) { // 将常见的linux分区过滤掉 if (line.contains(“proc”) || line.contains(“tmpfs”) || line.contains(“media”) || line.contains(“asec”) || line.contains(“secure”) || line.contains(“system”) || line.contains(“cache”) || line.contains(“sys”) || line.contains(“data”) || line.contains(“shell”) || line.contains(“root”) || line.contains(“acct”) || line.contains(“misc”) || line.contains(“obb”)) { continue; }

// 下面这些分区是我们需要的 if (line.contains(“fat”) || line.contains(“fuse”) || (line.contains(“ntfs”))){ // 将mount命令获取的列表分割,items[0]为设备名,items[1]为挂载路径 String items[] = line.split(” “); if (items != null && items.length > 1){ String path = items[1].toLowerCase(Locale.getDefault()); // 添加一些判断,确保是sd卡,如果是otg等挂载方式,可以具体分析并添加判断条件 if (path != null && !PathList.contains(path) && path.contains(“sd”)) PathList.add(items[1]); } } } } catch (Exception e){ // TODO Auto-generated catch block e.printStackTrace(); }

if (!PathList.contains(firstPath)) { PathList.add(firstPath); }

return PathList; }

另外还需要附上源码的下载地址:

http://download.csdn.net/download/yql44137228/10215688

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/171937.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档