Добавление той же строки к списку строк в Python - PullRequest
142 голосов
/ 12 января 2010

Я пытаюсь взять одну строку и добавить ее к каждой строке, содержащейся в списке, а затем получить новый список с завершенными строками. Пример:

list = ['foo', 'fob', 'faz', 'funk']
string = 'bar'

*magic*

list2 = ['foobar', 'fobbar', 'fazbar', 'funkbar']

Я пытался зацикливаться и пытаться понять список, но это был мусор. Как всегда, любая помощь, высоко ценится.

Ответы [ 10 ]

239 голосов
/ 12 января 2010

Самый простой способ сделать это с использованием списка:

[s + mystring for s in mylist]

Обратите внимание, что я избегал использования встроенных имен, таких как list, потому что это скрывает или скрывает встроенные имена, что очень плохо.

Кроме того, если вам на самом деле не нужен список, а нужен только итератор, выражение генератора может быть более эффективным (хотя это вряд ли имеет значение для коротких списков):

(s + mystring for s in mylist)

Они очень мощные, гибкие и лаконичные. Каждый хороший программист на Python должен научиться владеть ими.

20 голосов
/ 12 января 2010
my_list = ['foo', 'fob', 'faz', 'funk']
string = 'bar'
my_new_list = [x + string for x in my_list]
print my_new_list

Будет напечатано:

['foobar', 'fobbar', 'fazbar', 'funkbar']
2 голосов
/ 14 августа 2018

Расширение немного до «Добавление списка строк к списку строк»:

    import numpy as np
    lst1 = ['a','b','c','d','e']
    lst2 = ['1','2','3','4','5']

    at = np.full(fill_value='@',shape=len(lst1),dtype=object) #optional third list
    result = np.array(lst1,dtype=object)+at+np.array(lst2,dtype=object)

Результат:

array(['a@1', 'b@2', 'c@3', 'd@4', 'e@5'], dtype=object)

dtype odject может быть дополнительно преобразован в str

2 голосов
/ 15 февраля 2017

Запуск следующего эксперимента по питоническому пути:

[s + mystring for s in mylist]

кажется на 35% быстрее, чем очевидное использование цикла for, подобного этому:

i = 0
for s in mylist:
    mylist[i] = s+mystring
    i = i + 1

Эксперимент

import random
import string
import time

mystring = '/test/'

l = []
ref_list = []

for i in xrange( 10**6 ):
    ref_list.append( ''.join(random.choice(string.ascii_lowercase) for i in range(10)) )

for numOfElements in [5, 10, 15 ]:

    l = ref_list*numOfElements
    print 'Number of elements:', len(l)

    l1 = list( l )
    l2 = list( l )

    # Method A
    start_time = time.time()
    l2 = [s + mystring for s in l2]
    stop_time = time.time()
    dt1 = stop_time - start_time
    del l2
    #~ print "Method A: %s seconds" % (dt1)

    # Method B
    start_time = time.time()
    i = 0
    for s in l1:
        l1[i] = s+mystring
        i = i + 1
    stop_time = time.time()
    dt0 = stop_time - start_time
    del l1
    del l
    #~ print "Method B: %s seconds" % (dt0)

    print 'Method A is %.1f%% faster than Method B' % ((1 - dt1/dt0)*100)

Результаты

Number of elements: 5000000
Method A is 38.4% faster than Method B
Number of elements: 10000000
Method A is 33.8% faster than Method B
Number of elements: 15000000
Method A is 35.5% faster than Method B
2 голосов
/ 07 октября 2013

map кажется мне подходящим инструментом для работы.

my_list = ['foo', 'fob', 'faz', 'funk']
string = 'bar'
list2 = map(lambda orig_string: orig_string + string, my_list)

См. в этом разделе об инструментах функционального программирования для получения дополнительных примеров map.

2 голосов
/ 12 января 2010

Я не нашел способа комментировать ответы до сих пор. Так и здесь. Я поддерживаю ответ Игнасио Васкеса-Абрамса о list2 = ['%sbar' % x for x in list].

Ответы других с [string + "bar" for string in list] будут работать большую часть времени, но если вы примете более общее решение для простейшего случая, вы - ИМХО - будете следовать Принципам разработки Python. Должен быть один очевидный способ сделать это. %sbar работает постоянно.

1 голос
/ 16 июня 2016

вы можете использовать лямбду внутри карты в python.написал генератор серых кодов.https://github.com/rdm750/rdm750.github.io/blob/master/python/gray_code_generator.py # здесь идет ваш код '' 'n-1 битный код, с 0 перед каждым словом, за которым следует n-1 битный код в обратном порядке, с 1 перед каждым словом'' '

    def graycode(n):
        if n==1:
            return ['0','1']
        else:
            nbit=map(lambda x:'0'+x,graycode(n-1))+map(lambda x:'1'+x,graycode(n-1)[::-1])
            return nbit

    for i in xrange(1,7):
        print map(int,graycode(i))
0 голосов
/ 25 апреля 2019

Вот простой ответ, используя pandas.

import pandas as pd
list = ['foo', 'fob', 'faz', 'funk']
string = 'bar'

list2 = (pd.Series(list) + string).tolist()
list2
# ['foobar', 'fobbar', 'fazbar', 'funkbar']
0 голосов
/ 12 января 2010
new_list = [word_in_list + end_string for word_in_list in old_list]

Использование имен, таких как «список», для имен переменных недопустимо, поскольку оно перезапишет / переопределит встроенные функции.

0 голосов
/ 12 января 2010
list2 = ['%sbar' % (x,) for x in list]

И не используйте list в качестве имени; затеняет встроенный тип.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...