V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐学习书目
Learn Python the Hard Way
Python Sites
PyPI - Python Package Index
http://diveintopython.org/toc/index.html
Pocoo
值得关注的项目
PyPy
Celery
Jinja2
Read the Docs
gevent
pyenv
virtualenv
Stackless Python
Beautiful Soup
结巴中文分词
Green Unicorn
Sentry
Shovel
Pyflakes
pytest
Python 编程
pep8 Checker
Styles
PEP 8
Google Python Style Guide
Code Style from The Hitchhiker's Guide
ztoben
V2EX  ›  Python

日志树的生成

  •  
  •   ztoben · 2021-08-19 11:28:32 +08:00 · 2787 次点击
    这是一个创建于 1177 天前的主题,其中的信息可能已经有所发展或是发生改变。

    各位大佬,请教一个问题 这种日志树是怎么生成的? 。。。 发现了一个问题 V2EX 无法发图片 算了 直接看他的返回格式

    com.cityminsu.rba.baseinfo.api.vo.ProductVo
    ├──价格结束时间:'Mon Nov 15 00:00:00 CST 2021'->'Tue Mar 22 16:29:00 CST 2022'
    ├──产品状态:'下架'->'上架'
    ├──规则模版
    │    ├──是否可退:'取消扣全款'->'限时取消'
    │    ├──rbaRatePlanScope
    │    │    └──rbaRatePlanScopeList
    │    │         ├──:添加 '[houseList=[0]=0;orgId=0]'
    │    │         └──:删除 '[houseList=[0]=0;orgId=0]'
    │    └──stayDaysProduct:添加 '[[StayDaysProductVo{productId=null, stayDays=2, discountRatio=80, productStatus=1, active=0}]=[active=0;discountRatio=80;productStatus=1;stayDays=2];[StayDaysProductVo{productId=null, stayDays=3, discountRatio=79, productStatus=1, active=0}]=[active=0;discountRatio=79;productStatus=1;stayDays=3];[StayDaysProductVo{productId=null, stayDays=5, discountRatio=77, productStatus=1, active=0}]=[active=0;discountRatio=77;productStatus=1;stayDays=5];[StayDaysProductVo{productId=null, stayDays=7, discountRatio=75, productStatus=1, active=0}]=[active=0;discountRatio=75;productStatus=1;stayDays=7]]'
    ├──价格开始时间:'Wed Aug 18 00:00:00 CST 2021'->'Wed Aug 18 16:29:00 CST 2021'
    ├──平日价:'0.00'->'1000.00'
    └──周末价:'0.00'->'1000.00'
      覆盖方式: '不覆盖日历上单独设立价格'
    

    可以看到他返回的就是这种树状结构 请问是怎么实现的

    18 条回复    2021-08-19 21:47:36 +08:00
    ztoben
        1
    ztoben  
    OP
       2021-08-19 11:30:46 +08:00
    这种利用 “\n” 和“|”实现的树状结构
    ztoben
        2
    ztoben  
    OP
       2021-08-19 11:44:57 +08:00
    彦祖们 有没有思路啊 别光看看啊
    Building
        3
    Building  
       2021-08-19 12:00:42 +08:00 via iPhone
    如果上过 C 语言课程,作业就有打印各种形状的星星…
    ColinZeb
        4
    ColinZeb  
       2021-08-19 13:45:03 +08:00
    记录的时候带上 Scope,打印就简单了
    ztoben
        5
    ztoben  
    OP
       2021-08-19 13:45:13 +08:00
    @Building 这个谁都会打。。。 星星他会告诉你他什么怎么个规则 这个不会
    ztoben
        6
    ztoben  
    OP
       2021-08-19 13:45:41 +08:00
    @ColinZeb 大哥能讲的详细点吗
    szyp
        7
    szyp  
       2021-08-19 13:53:56 +08:00   ❤️ 1
    python 可以使用 rich.tree
    https://github.com/willmcgugan/rich
    ztoben
        8
    ztoben  
    OP
       2021-08-19 14:04:34 +08:00
    @szyp 大哥我看了哈 可能都理解错了 我不是要输出这样的格式 我是要返回这样的格式
    reallittoma
        9
    reallittoma  
       2021-08-19 14:08:49 +08:00
    @ztoben 输出跟返回有区别吗
    ztoben
        10
    ztoben  
    OP
       2021-08-19 14:10:26 +08:00
    @reallittoma 有道理
    qwq11
        11
    qwq11  
       2021-08-19 14:34:21 +08:00
    这个不就是序列化一下吗,定义一个 interface{ GetStructuralInfomation() } 返回一个节点的这样的树,递归调用就行了,还可以给每个字段加个 annotation 自动识别名字和格式,就更简单了
    qwq11
        12
    qwq11  
       2021-08-19 15:00:58 +08:00
    ```javascript
    function getDescString(o, indent) {
    switch (typeof (o)) {
    case 'object':
    let arr = []
    if (Array.isArray(o)) {
    for (let i = 0; i < o.length; i++) {
    arr.push(`${indent}- ${i}: ${getDescString(o[i], indent + ' ')}`)
    }
    } else {
    for (var item in o) {
    arr.push(`${indent}${item}: ${getDescString(o[item], indent + ' ')}`)
    }
    }
    return '\n' + arr.join('\n')
    default:
    return o
    }
    }

    let obj = { "msg": "就这样", "tips": [{ "id": 1, "content": "代码挺乱嘻嘻" }, { "id": 2, "content": "再来一个提示" }] }
    console.log(getDescString(obj, ''))
    ```
    发现稍微改下就可以生成 yaml (
    ztoben
        13
    ztoben  
    OP
       2021-08-19 15:08:23 +08:00
    @qwq11 感谢 等我研究研究 js 代码先
    ztcaoll222
        14
    ztcaoll222  
       2021-08-19 15:39:03 +08:00
    ```java
    @Orrvide
    public String toString() {
    this.class.getFieldss().forEach(it -> {
    var annotation = it.getAnnotation(XX.class);
    if (annotation == null) {
    sout("|--" + field.name + ":" + field.get(this).toString())
    } else {
    sout("|--" + annotation.value + ":" + field.get(this).toString())
    }
    })
    }
    ```
    伪代码,你将就看,其中数组这些可能要特殊处理一下
    ztcaoll222
        15
    ztcaoll222  
       2021-08-19 16:01:33 +08:00
    盲写还是有问题,这样,细微的自己调,继承这个接口就行了
    ```java
    public interface Printer {
    default String toString(int dept) throws IllegalAccessException {
    String prefix = "";
    if (dept != 0) {
    prefix = "|" + " ".repeat(dept * 2);
    }
    StringBuilder sb = new StringBuilder();
    for (Field field : this.getClass().getDeclaredFields()) {
    field.setAccessible(true);
    Object value = field.get(this);
    if (value instanceof Printer) {
    sb.append(prefix).append("├──").append(field.getName()).append(": ").append("\n").append(((Printer) value).toString(dept + 1));
    } else {
    sb.append(prefix).append("├──").append(field.getName()).append(": ").append(value.toString()).append("\n");
    }
    }
    return sb.toString();
    }
    }
    ```
    summerLast
        16
    summerLast  
       2021-08-19 17:56:20 +08:00
    不是很复杂 伪代码
    function log(obj,level,isLast){
    for(let k in obj){
    // TODO isLast
    let isLast
    if(obj[k] is Object){
    log(obj[k],level+1,isLast)
    }else{
    console.log(isLast?'└':'├',"- ".repeat(level),k,":",obj[k])
    }
    }
    }
    buddyy
        17
    buddyy  
       2021-08-19 19:02:12 +08:00
    看标题我以为在 LSM-Tree 呢。
    z740713651
        18
    z740713651  
       2021-08-19 21:47:36 +08:00
    问题在 python 下
    写了个 handler
    还挺好玩的。。。

    https://gist.github.com/AngusWG/68bb83b53e872b894b4698f6b18c27ae
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2802 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 25ms · UTC 13:22 · PVG 21:22 · LAX 05:22 · JFK 08:22
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.