[['chang'], ['du'], ['zhang', 'chang']] 如何拼成 “changduchangchangduzhang”呢 - 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
twor

[['chang'], ['du'], ['zhang', 'chang']] 如何拼成 “changduchangchangduzhang”呢

  •  
  •   twor Feb 1, 2019 3540 views
    This topic created in 2660 days ago, the information mentioned may be changed or developed.
    [['chang'], ['du'], ['zhang', 'chang']] 如何拼成 “ changduchangchangduzhang ”呢
    用途就是生成字段的拼音的各种情况,方便拼音检索
    或者有其他思路?
    Supplement 1    Feb 1, 2019
    感谢 @Procumbens ,100%符合,结帖

    其他的有些童鞋估计没有领会到我神一般的表达,不是我要的
    另外一些,我的确看不懂,比如 @momocraft @jiejiss 等 ,我正在通过谷歌学习他们的回帖,:(

    再补充下应用场景
    比如 有一个字段是 “长度长”,我希望用户无论是搜索,“ cdc ” 或者 “ cdz ” 都可以搜索到
    17 replies    2019-02-15 00:44:39 +08:00
    zst
        1
    zst  
       Feb 1, 2019 via Android
    可以 flatten 以后直接拼起来?
    momocraft
        2
    momocraft  
       Feb 1, 2019   1
    .reduce(笛卡尔积).map(join).join (然后自己改成 python 语法)
    EulerChen
        3
    EulerChen  
       Feb 1, 2019 via Android   1
    arr.flat().join('')即可

    flat 特性已在 ES2019 正式支持
    sdijeenx
        4
    sdijeenx  
       Feb 1, 2019   1
    >>> for i in itertools.permutations([['chang'], ['du'], ['zhang', 'chang']] , 3):
    ... print(i)
    ...
    (['chang'], ['du'], ['zhang', 'chang'])
    (['chang'], ['zhang', 'chang'], ['du'])
    (['du'], ['chang'], ['zhang', 'chang'])
    (['du'], ['zhang', 'chang'], ['chang'])
    (['zhang', 'chang'], ['chang'], ['du'])
    (['zhang', 'chang'], ['du'], ['chang'])

    这样应该满足 LZ 要求=3=
    Trim21
        5
    Trim21  
       Feb 1, 2019 via Android
    先 flat 再 join
    Procumbens
        6
    Procumbens  
       Feb 1, 2019   2
    import itertools
    sample = [['chang'], ['du'], ['zhang', 'chang']]
    result = list(itertools.product(*sample))
    for i in result:
    print(''.join(i))
    Procumbens
        7
    Procumbens  
       Feb 1, 2019   1
    就 2L 说的笛卡尔积是对的,LS 说 flat 的都没了解 LZ 想要什么……
    BTW,LS 我的代码最后一行的缩进被吃了
    sdijeenx
        8
    sdijeenx  
       Feb 1, 2019   1
    刚才又写了个偷鸡算法,结果还是 LS 的更好用。
    dushixiang
        9
    dushixiang  
       Feb 1, 2019 via iPhone   1
    flatMap 成一个数组,然后拼成一个串。
    loading div class="fr">     10
    loading  
       Feb 1, 2019 via Android   1
    楼上都很厉害,我只能发个结帖算法了:
    if foo=="[['chang'], ['du'], ['zhang', 'chang']] " then
    foo="changduchangchangduzhang"
    fonlan
        11
    fonlan  
       Feb 1, 2019 via Android   1
    再来个另类的,把 List 转 str 然后用正则取出所有字母即可
    jiejiss
        12
    jiejiss  
       Feb 1, 2019 via Android   1
    用 built in 的工具库算笛卡尔积,或者手写 DFS。DFS 递归写着还蛮方便的。之前不知道笛卡尔积的时候就是手写的 DFS
    jiejiss
        13
    jiejiss  
       Feb 1, 2019 via Android   1
    或者把大数组当成一个有向图,每个子数组都是一层,每个字符串是一个节点。之后强行在最前面插一个空字符串节点来充当根结点。之后遍历一遍就好了
    wuhaochen999
        14
    wuhaochen999  
       Feb 1, 2019
    cartesian product
    Ama2in9
        15
    Ama2in9  
       Feb 1, 2019 via iPhone
    @loading 哈哈哈哈哈你他娘的真是个人才
    qilishasha
        16
    qilishasha  
       Feb 2, 2019
    @loading 优秀的程序员很多,有趣的灵魂唯独你一只
    luoleng
        17
    luoleng  
       Feb 15, 2019
    ''.join(re.findall(r'\w+?', str(your_list)))
    About     Help     Advertise     Blog     API     FAQ     Solana     894 Online   Highest 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 54ms UTC 21:35 PVG 05:35 LAX 14:35 JFK 17:35
    Do have faith in what you're doing.
    ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86