加入收藏 | 设为首页 | 会员中心 | 我要投稿 商洛站长网 (https://www.0914zz.com/)- AI应用、CDN、边缘计算、云计算、物联网!
当前位置: 首页 > 编程开发 > Python > 正文

Python分隔线分割问题

发布时间:2020-12-30 19:02:05 所属栏目:Python 来源:互联网
导读:我正在努力分割文本行,基于变量分隔符,并保留空字段和引用的数据. 例子: 1,2,three,four, 4,,6tsix 或作为制表符分隔的vesion 1t2tthreetfour, 4tt6tsix 都应该导致: [1, 2, three, four, 4, , 6tsix] 到目前为止,我已经尝试过: 使用split,但

我正在努力分割文本行,基于变量分隔符,并保留空字段和引用的数据.

例子:

1,"2",three,'four,4',"6tsix"

或作为制表符分隔的vesion

1t"2"tthreet'four,4'tt"6tsix"

都应该导致:

['1','"2"','three','',"6tsix"]

到目前为止,我已经尝试过:

>使用split,但是明确地说,引用的分隔符不按需要处理.
>使用csv库的解决方案,但它倾向于具有引用全部或全部内容的选项,而不保留原始引号.
>正则表达式,特别是从以下答案的模式,但它删除空字段:How to split but ignore separators in quoted strings,in python?
>使用pyparsing库.我管理的最好的是如下,但这也会删除空字段(使用逗号分隔符示例):

s = '1,'four,4',"6tsix"'
wordchars = (printables + ' trn').replace(',',1)
delimitedList(OneOrMore(quotedString | Word(wordchars)),').parseWithTabs().parseString(s)

感谢任何想法!

解决方法

这对我有用:
import pyparsing as pyp

pyp.delimitedList(pyp.quotedString | pyp.SkipTo(',' | pyp.LineEnd()),') 
    .parseWithTabs().parseString(s)

['1',"'four,4'",'"6tsix"']

避免用空格字符或所有可打印字符创建单词.曲折不会有任何前瞻性,而这些表达可能包含比您计划的更多.

(编辑:商洛站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读