Atitit。Tree文件解析器的原理流程与设计实现  java  c# php js

Atitit。Tree文件解析器的原理流程与设计实现  java  c# php js

1. 解析原理与流程1

1.1. 判断目录  ,表示服  dirFlagChar = "└├─";1

1.2. 剑豪制表符出现的位置与文件夹级别对应表1

1.3. 主要判读流程2

2. Tree结果2

3. Code----3

4. 结果5

1. 解析原理与流程

1.1. 判断目录  ,表示服  dirFlagChar = "└├─";

其中-类似于剑豪的制表符是表示目录的。。够好表示最后的目录,t制表符表示中间的目录。。

1.2. 剑豪制表符出现的位置与文件夹级别对应表


prefix


lev1


2


1


5


2


6


2


9


3


12


4


13


4


16


5


17


5


20


6


21


6


24


7


27


8


28


8

作者:: 绰号:老哇的爪子 ( 全名::Attilax Akbar Al Rapanui 阿提拉克斯 阿克巴 阿尔 拉帕努伊 ) 汉字名:艾龙,  EMAIL:[email protected]

转载请注明来源: http://www.cnblogs.com/attilax/

1.3. 主要判读流程

if (level_curdir > level_lastdir)

lastDir = lastDir + "/" + curdirName;

else if(level_curdir==level_lastdir)

lastDir = getCurDirParent(level_curdir, lastDir) + "/"+curdirName;

else

lastDir = getCurDirParent(level_curdir, lastDir) + "/"

2. Tree结果

文件夹 PATH 列表

卷序列号为 802A-6864

C:.

│  .classpath

│  .mymetadata

│  .myumldata

│  .project

│  build.xml

│  myprocessdefinition1.xml

│  readme.txt

│  tree.txt

├─.settings

│      com.genuitec.eclipse.j2eedt.core.prefs

├─src

│  │  applicationContext-actions.xml

│  │  applicationContext-beans.xml

│  │  applicationContext-common.xml

│  │  hibernate.cfg.xml

│  │  init_datas.xml

│  │  jbpm.cfg.xml

│  │  log4j.properties

│  │  MessageResources.properties

│  │  test.java

3. Code----

public class TreeUtil {

private String encode;

private String path;

public TreeUtil(String p, String e) {

path = p;

encode = e;

}

public static String lastDir;

public static void main(String[] args) {

// TODO Auto-generated method stub

// 4>1,7>2,11>3,13>4

// dir 2>2, 5>3,9>4, 13>5 17>6 20>7

// countLengestFolderPath();

final String start = "c:\\myoa";

String dirFlagChar = "└├─";

final String dirFlagChar1 = "─";

AFile f = new AFile("c:\\myoa\\tree.txt", "gbk");

final Set st = Sets.newConcurrentHashSet();

lastDir = "";

final DbStroreEngieen dbs = new DbStroreEngieen(pathx.webAppPath()

+ "/db/db1");

final List<Map> table = dbs.getTableRecs("dirLevel");

f.trave(new Closure<String, Object>() {

@Override

public Object execute(String line) throws Exception {

if (line.contains(dirFlagChar1)) {

int preIndex = line.indexOf(dirFlagChar1) + 1;

String curdirName = get_curdirName(preIndex, line);

if( curdirName.equals("com"))

System.out.println("dbg");

Map row = dbs.getRow(table, "prefix", preIndex);

int level_curdir = new ANum( row.get("lev1")).toInt();

int level_lastdir = get_level_curdir(lastDir);

if (level_curdir > level_lastdir) //src/com/zhaohui/oa/freemarker/templates

lastDir = lastDir + "/" + curdirName;

else if(level_curdir==level_lastdir)

lastDir = getCurDirParent(level_curdir, lastDir) + "/"+curdirName;

else

lastDir = getCurDirParent(level_curdir, lastDir) + "/"

+ curdirName;

lastDir=  AString.LTrim(lastDir,"/");

st.add(preIndex);

String idex = new ANum(preIndex).toStr();

//System.out.println(idex + ":" + line);

System.out.println(lastDir);

}

return null;

}

//1    ".sett"

private String getCurDirParent(int level_curdir, String lastDir) {

String[] a = lastDir.split("/");

List<String> li = Lists.newArrayList();

for (int i = 0; i < level_curdir-1; i++) {

li.add(a[i]);

}

return com.attilax.collection.CollectionUtils.join(li, "/");

}

private String get_curdirName(int preIndex, String line) {

// TODO Auto-generated method stub

return line.substring(preIndex);

}

private int get_level_curdir(String lastDir) {

if(lastDir.equals("")) return 0;

String[] a = lastDir.split("/");

return a.length ;

}

});

List li = Lists.newArrayList();

li.addAll(st);

Collections.sort(li);

// List li2=

// from(li).orderby().exe();

// ACollections.set2list(st);

System.out.println(AtiJson.toJson(li));

System.out.println("--f");

}

4. 结果

.settings

src

dbg

src/com

src/com/zhaohui

src/com/zhaohui/oa

src/com/zhaohui/oa/freemarker

src/com/zhaohui/oa/freemarker/templates

src/com/zhaohui/oa/manager

src/com/zhaohui/oa/manager/impl

src/com/zhaohui/oa/model

src/com/zhaohui/oa/util

src/com/zhaohui/oa/web

src/com/zhaohui/oa/web/actions

src/com/zhaohui/oa/web/forms

test

Dbg

----end

时间: 2024-10-10 06:33:00

Atitit。Tree文件解析器的原理流程与设计实现  java  c# php js的相关文章

javap -- Java 类文件解析器

参考文档 http://blog.chinaunix.net/uid-692788-id-2681132.html http://docs.oracle.com/javase/7/docs/technotes/tools/solaris/javap.html 功能说明:Java 类文件解析器. 语法:javap [ 命令选项 ] class. . . 补充说明: javap 命令用于解析类文件.其输出取决于所用的选项.若没有使用选项,javap 将输出传递给它的类的 public 域及方法.ja

XML文件解析器TXml

前几天看了开源的XML文件解析器TinyXml,它是怎么实现解析的没怎么看懂,于是决定自己实现一个,反正最近不忙.先命名为TXml.现在完成了解析和查询功能,全部代码加起来不到1000行,将会继续完善它.源码必共享 先简单说一下我的思路: 1:读取XML文件信息,并存入一个字符数组中: 2:遍历数组,将数组解析成一棵树: 3:以路径的方式查询和按属性查询: 这个解析器最麻烦的地方就在怎么将字符数组解析成一颗树.我们先看一下一个简单XML文件,他包括文件头.节点.节点名称及节点值.属性名称及属性值

Atitit.论图片类型&#160;垃圾文件的识别与清理&#160;&#160;流程与设计原则&#160;与api概要设计&#160;v2&#160;pbj

Atitit.论图片类型 垃圾文件的识别与清理  流程与设计原则 与api概要设计 v2 pbj 1. 俩个问题::识别垃圾文件与清理策略1 2. 如何识别垃圾图片1 2.1. 体积过小文件<10kb1 2.2. 增加扩展名对于无扩展名文件1 2.3. 清理非图片(bmp,jpg,jpeg,png)的文件2 2.4. 尺寸过小图片(210*150)2 2.5. 清理广告图片(高度宽度不成比例)超长超宽图片2 2.6. 清理重复图片(此结果不能加入指纹库)2 2.7. 非本类别的图片(人工识别)2

C++PE文件格式解析类(轻松制作自己的PE文件解析器)

PE是Portable Executable File Format(可移植的运行体)简写,它是眼下Windows平台上的主流可运行文件格式. PE文件里包括的内容非常多,详细我就不在这解释了,有兴趣的能够參看之后列出的參考资料及其它相关内容. 近期我也在学习PE文件格式,參考了很多资料.用C++封装了一个高效方便的PE文件格式解析的类. 该类对想学PE文件结构的朋友可算一份可贵的资料.代码均非常易懂,考虑较全面,具有一定的通用性. 同一时候该类也能够让想创建自己的PE文件解析软件的朋能够轻松在

springMVC:为MultipartFilte配置了上传文件解析器,报错或不能使用

一.问题描述为支持restful风格请求,并且应对可能上传文件的情况,需要在配置hiddenHttpMethodFilter过滤器之前配置MultipartFilter.目的是让MultipartFilter过滤器先将带文件上传的请求,进行解析.以便hiddenHttpMethodFilter可以取到”_method”参数,转化为相应的http动作. 既然multipartFilter要进行上传文件的解析,那么必然需要MutipartResolver,那么问题发生了! 二.报错:Unable t

TinyDBF-用200行的DBF解析器来展示良好架构设计

由于工作关系,需要工作当中,需要读取DBF文件,找了一些DBF读取开源软件,要么是太过庞大,动不动就上万行,要么是功能有问题,编码,长度,总之是没有找到一个非常爽的.在万般无奈之下,我老人家怒从心头起,恶向胆边生,决定自己写一下.结果只用了不到300行代码就搞定了,当然搞定不是唯一目标,还要优雅简洁的搞定,亲们跟随我的脚步一起感受一下简洁的设计与实现吧. 在开始编码之前,先介绍一下DBF,这个DBF可是个老东西,在DOS时代就已经出现,并且风骚了相当一段时间,后来随着大型数据库的应用,它逐步没落

《自己动手写框架2》:用200行的DBF解析器来展示良好架构设计

由于工作关系,需要工作当中,需要读取DBF文件,找了一些DBF读取开源软件,要么是太过庞大,动不动就上万行,要么是功能有问题,编码,长度,总之是没有找到一个非常爽的.在万般无奈之下,我老人家怒从心头起,恶向胆边生,决定自己写一下.结果只用了不到300行代码就搞定了,当然搞定不是唯一目标,还要优雅简洁的搞定,亲们跟随我的脚步一起感受一下简洁的设计与实现吧. 在开始编码之前,先介绍一下DBF,这个DBF可是个老东西,在DOS时代就已经出现,并且风骚了相当一段时间,后来随着大型数据库的应用,它逐步没落

Dicom格式文件解析器

转自:http://www.cnblogs.com/assassinx/archive/2013/01/09/dicomViewer.html Dicom全称是医学数字图像与通讯,这里讲的暂不涉及通讯那方面的问题 只讲*.dcm 也就是diocm格式文件的读取,读取本身是没啥难度的 无非就是字节码数据流处理.只不过确实比较繁琐. 分析: 整体结构先是128字节所谓的导言部分,说俗点就是没啥意义的破数据 跳过就是了,然后是dataElement依次排列的方式 就是一个dataElement接一个d

ReadGEXF:C++版gexf文件解析器(目前仅测试Gephi生成的gexf文件)

项目地址:https://github.com/xysmlx/ReadGEXF 简易的读取gexf文件的程序,C++版本(适用于Windows/Linux) 后续计划功能:生成gexf文件 README: # ReadGEXF A simple GEXF file reader by C++ ## Version 0.1 This version can read gexf file generated by Gephi. ## Build ======================= g++