python列表切片和推导式思维导图_Python - 将思维导图转换为关系型数据结构

#!/usr/bin/env python3

# -*- coding: utf-8 -*-

"""

Created on Mon Feb 10 15:24:07 2020

Convert mindmap txt file to relational database structure.

The mindmap text file marks the level by tab.

@author: ydx

"""

import os

import sys

input = sys.argv[1]

output = sys.argv[2]

f_i = open(input, mode='r', encoding='utf-8')

f_o = open(output, mode='w', encoding='utf-8')

f_o.write('name,lvl,rid,prid,bseq'+'\n')

rid = 1 #row id

bseq = 1 #branch sequence

l_rid = [1] #list of row id

l_bseq = [1] #list of branch sequence

lvl_h = 0 #level hold

lvl_max = 0 #max level

for x in f_i:

lvl = x.rstrip().count('\t')

if lvl > lvl_h:

bseq=1

f_o.write(x.strip()+','+str(lvl)+','+str(rid)+','+str(l_rid[lvl-1])+','+str(bseq)+'\n')

if lvl > lvl_max:

lvl_max = lvl

l_rid.append(rid)

l_bseq.append(bseq)

else:

l_rid[lvl] = rid

l_bseq[lvl] = bseq

rid+=1

lvl_h = lvl

elif lvl <= lvl_h:

bseq = l_bseq[lvl]+1

f_o.write(x.strip()+','+str(lvl)+','+str(rid)+','+str(l_rid[lvl-1])+','+str(bseq)+'\n')

l_rid[lvl] = rid

l_bseq[lvl] = bseq

rid+=1

lvl_h = lvl

else:

f_o.write(x.strip()+','+str(lvl)+','+str(rid)+','+str(l_rid[lvl-1])+','+str(bseq)+'\n')

l_rid[lvl] = rid

l_bseq[lvl] = bseq

f_i.close()

f_o.close()

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值