您好, 欢迎来到 !    登录 | 注册 | | 设为首页 | 收藏本站

Python分隔线分割问题

5b51 2022/1/14 8:22:49 python 字数 1833 阅读 619 来源 www.jb51.cc/python

我正在努力分割文本行,基于变量分隔符,并保留空字段和引用的数据. 例子: 1,"2",three,'four, 4',,"6\tsix" 或作为制表符分隔的vesion 1\t"2"\tthree\t'four, 4'\t\t"6\tsix" 都应该导致: ['1', '"2"', 'three', 'four, 4', '', "6\tsix"] 到目前为止,我已经尝试过: >使用split,但

概述

例子:

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

或作为制表符分隔的vesion

1\t"2"\tthree\t'four,4'\t\t"6\tsix"

都应该导致:

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

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

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

s = '1,\'four,4\',"6\tsix"'
wordchars = (printables + ' \t\r\n').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'",'"6\tsix"']

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

总结

以上是编程之家为你收集整理的Python分隔线分割问题全部内容,希望文章能够帮你解决Python分隔线分割问题所遇到的程序开发问题。


如果您也喜欢它,动动您的小指点个赞吧

除非注明,文章均由 laddyq.com 整理发布,欢迎转载。

转载请注明:
链接:http://laddyq.com
来源:laddyq.com
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。


联系我
置顶