您的位置:首页 > 移动开发 > Android开发

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

2018-01-20 16:28 411 查看
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


内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  工具代码说明