In JavaScript, I can use splice
to insert an array of multiple elements in to an array: myArray.splice(insertIndex, removeNElements, ...insertThese)
.
But I can't seem to find a way to do something similar in Python without having concat lists. Is there such a way? (There is already a Q&A about inserting single items, rather than multiple.)
For example myList = [1, 2, 3]
and I want to insert otherList = [4, 5, 6]
by calling myList.someMethod(1, otherList)
to get [1, 4, 5, 6, 2, 3]
You can use the sequence method list. extend to extend the list by multiple values from any kind of iterable, being it another list or any other thing that provides a sequence of values. So you can use list. append() to append a single value, and list.
When you wish to append multiple items to a list and the goal is to store them as separate entities/elements, use the extend function. Since the extend function has been implemented in C, it would be comparatively quicker than append .
append(input()) print("\nEnter an Element to Insert at End: ") elem = input() nums. append(elem) numsSize = numsSize+1 print("\nThe New List is: ") for i in range(numsSize): print(end=nums[i] + " ") print() except ValueError: print("\nInvalid Input!
To extend a list, you just use list.extend
. To insert elements from any iterable at an index, you can use slice assignment...
>>> a = list(range(10))
>>> a
[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
>>> a[5:5] = range(10, 13)
>>> a
[0, 1, 2, 3, 4, 10, 11, 12, 5, 6, 7, 8, 9]
Python lists do not have such a method. Here is helper function that takes two lists and places the second list into the first list at the specified position:
def insert_position(position, list1, list2):
return list1[:position] + list2 + list1[position:]
I'm not certain this question is still being followed but I recently wrote a short code that resembles what is being asked here. I was writing an interactive script to perform some analyses so I had a series of inputs serving to read in certain columns from a CSV:
X = input('X COLUMN NAME?:\n')
Y = input('Y COLUMN NAME?:\n')
Z = input('Z COLUMN NAME?:\n')
cols = [X,Y,Z]
Then, I brought the for-loop into 1 line to read into the desired index position:
[cols.insert(len(cols),x) for x in input('ENTER COLUMN NAMES (COMMA SEPARATED):\n').split(', ')]
This may not necessarily be as concise as it could be (I would love to know what might work even better!) but this might clean some of the code up.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With