Appending Strings in Python

Introduction

In Python, strings are a sequence of characters and are one of the most used data types. There are lots of scenarios (taking user input, reading data from files, etc) where you'll need to append one string to another.

This Byte will guide you through the basic ways of appending strings in Python.

Basic String Appending in Python

As we all know, Python is a very flexible language that makes it easy to do many common programming tasks. This is done by providing operators, methods, or other means to perform a task. As you'll see in the next few sections, there are quite a few ways to append strings.

Using the '+' Operator

The + operator is the most straightforward way to append strings in Python. However, it's worth noting that the + operator can only concatenate strings. If you try to use it with a non-string type, Python will raise a TypeError.

Here's an example:

str1 = "The answer is "
num = 42
str2 = str1 + num
print(str2)

This will raise the following error:

TypeError: can only concatenate str (not "int") to str

To fix this, you need to convert the non-string type to a string using the str() function:

str1 = "The answer is "
num = 42
str2 = str1 + str(num)
print(str2)

And the output will be:

The answer is 42

Using the '%' Operator

Another way to append strings in Python is by using the % operator. This operator is used for string formatting and can be a powerful tool for appending strings and non-string types.

Let's see an example:

num = 42
str1 = "The answer is %s" % num
print(str1)

The output will be:

The answer is 42

In this example, %s is a placeholder for a string. When the % operator is used, it replaces the placeholder with the value of num. Note that the % operator automatically converts non-string types to strings, so you don't need to use the str() function.

Get free courses, guided projects, and more

No spam ever. Unsubscribe anytime. Read our Privacy Policy.

Note: The % operator also supports other types of placeholders, such as %d for integers and %f for floating-point numbers.

Using the 'format()' Function

Python's built-in format() function is another versatile tool for string manipulation. It allows us to insert and format data in a string in a variety of ways. To append one string to another using the format() function, we can use placeholders, represented by curly braces {}.

Here's a basic example:

str1 = "Hello"
str2 = "World"
result = "{} {}".format(str1, str2)
print(result)

Output:

Hello World

In this example, the format() function replaces the {} placeholders with the arguments provided, in the order they are given.

Using the 'join()' Function

The join() function is a string method that concatenates a sequence of strings with a specified delimiter. If we want to append strings without any delimiter, we can use an empty string '' as the delimiter.

Here's how you can do it:

str1 = "Hello"
str2 = "World"
result = ''.join([str1, str2])
print(result)

Output:

HelloWorld

Note: The join() function expects an iterable (like a list or a tuple) as the argument, so we need to put our strings into a list or tuple.

Using 'f-string' Formatting

Introduced in Python 3.6, f-string formatting (also known as f-strings) is a new way to format strings in Python. It's faster, more readable, and less error-prone than other string formatting methods.

To append one string to another using f-strings, we can simply include the variables we want to append inside {} in the string. Here's an example:

str1 = "Hello"
str2 = "World"
result = f"{str1}{str2}"
print(result)

Output:

HelloWorld

Conclusion

In this Byte, we've covered different ways to append strings in Python using the format(), join(), and f-string methods. Each method has its own use-cases and advantages. The format() function is versatile and allows for complex string manipulations, the join() function is useful when dealing with lists of strings, and f-strings offer a more readable and efficient way to format strings.

Last Updated: August 28th, 2023
Was this helpful?

© 2013-2025 Stack Abuse. All rights reserved.

AboutDisclosurePrivacyTerms