Location via proxy:   [ UP ]  
[Report a bug]   [Manage cookies]                
0% found this document useful (0 votes)
47 views

Python - Strings: Accessing Values in Strings

Uploaded by

rash
Copyright
© © All Rights Reserved
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
47 views

Python - Strings: Accessing Values in Strings

Uploaded by

rash
Copyright
© © All Rights Reserved
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 10

Python - Strings
Advertisements

 Previous Page Next Page 

Strings are amongst the most popular types in Python. We can create them simply by
enclosing characters in quotes. Python treats single quotes the same as double quotes.
Creating strings is as simple as assigning a value to a variable. For example −

var1 = 'Hello World!'


var2 = "Python Programming"

Accessing Values in Strings


Python does not support a character type; these are treated as strings of length one, thus
also considered a substring.

To access substrings, use the square brackets for slicing along with the index or indices to
obtain your substring. For example −
 Live Demo
#!/usr/bin/python

var1 = 'Hello World!'


var2 = "Python Programming"

print "var1[0]: ", var1[0]


print "var2[1:5]: ", var2[1:5]

When the above code is executed, it produces the following result −

var1[0]: H
var2[1:5]: ytho

Updating Strings
You can "update" an existing string by (re)assigning a variable to another string. The new
value can be related to its previous value or to a completely different string altogether. For
example −
#!/usr/bin/python  Live Demo

var1 = 'Hello World!'


print "Updated String :- ", var1[:6] + 'Python'

When the above code is executed, it produces the following result −

Updated String :- Hello Python

Escape Characters
Following table is a list of escape or non-printable characters that can be represented with
backslash notation.

An escape character gets interpreted; in a single quoted as well as double quoted strings.

Backslash Hexadecimal
Description
notation character

\a 0x07 Bell or alert

\b 0x08 Backspace

\cx Control-x

\C-x Control-x

\e 0x1b Escape

\f 0x0c Formfeed

\M-\C-x Meta-Control-x

\n 0x0a Newline

\nnn Octal notation, where n is in the range 0.7

\r 0x0d Carriage return

\s 0x20 Space

\t 0x09 Tab

\v 0x0b Vertical tab

\x Character x

Hexadecimal notation, where n is in the range 0.9,


\xnn
a.f, or A.F
String Special Operators
Assume string variable a holds 'Hello' and variable b holds 'Python', then −

Operator Description Example

Concatenation - Adds values on either


+ a + b will give HelloPython
side of the operator

Repetition - Creates new strings,


* concatenating multiple copies of the a*2 will give -HelloHello
same string

Slice - Gives the character from the given


[] a[1] will give e
index

Range Slice - Gives the characters from


[:] a[1:4] will give ell
the given range

Membership - Returns true if a character


in H in a will give 1
exists in the given string

Membership - Returns true if a character


not in M not in a will give 1
does not exist in the given string

Raw String - Suppresses actual meaning


of Escape characters. The syntax for raw
strings is exactly the same as for normal
strings with the exception of the raw
print r'\n' prints \n and print R'\n'prints
r/R string operator, the letter "r," which
\n
precedes the quotation marks. The "r"
can be lowercase (r) or uppercase (R)
and must be placed immediately
preceding the first quote mark.

% Format - Performs String formatting See at next section

String Formatting Operator


One of Python's coolest features is the string format operator %. This operator is unique to
strings and makes up for the pack of having functions from C's printf() family. Following is
a simple example −
 Live Demo
#!/usr/bin/python

print "My name is %s and weight is %d kg!" % ('Zara', 21)

When the above code is executed, it produces the following result −


My name is Zara and weight is 21 kg!

Here is the list of complete set of symbols which can be used along with % −

Format Symbol Conversion

%c character

%s string conversion via str() prior to formatting

%i signed decimal integer

%d signed decimal integer

%u unsigned decimal integer

%o octal integer

%x hexadecimal integer (lowercase letters)

%X hexadecimal integer (UPPERcase letters)

%e exponential notation (with lowercase 'e')

%E exponential notation (with UPPERcase 'E')

%f floating point real number

%g the shorter of %f and %e

%G the shorter of %f and %E

Other supported symbols and functionality are listed in the following table −

Symbol Functionality

* argument specifies width or precision

- left justification

+ display the sign

<sp> leave a blank space before a positive number

add the octal leading zero ( '0' ) or hexadecimal leading '0x' or


#
'0X', depending on whether 'x' or 'X' were used.

0 pad from left with zeros (instead of spaces)

% '%%' leaves you with a single literal '%'


(var) mapping variable (dictionary arguments)

m is the minimum total width and n is the number of digits to


m.n.
display after the decimal point (if appl.)

Triple Quotes
Python's triple quotes comes to the rescue by allowing strings to span multiple lines,
including verbatim NEWLINEs, TABs, and any other special characters.

The syntax for triple quotes consists of three consecutive single or double quotes.
 Live Demo
#!/usr/bin/python

para_str = """this is a long string that is made up of


several lines and non-printable characters such as
TAB ( \t ) and they will show up that way when displayed.
NEWLINEs within the string, whether explicitly given like
this within the brackets [ \n ], or just a NEWLINE within
the variable assignment will also show up.
"""
print para_str

When the above code is executed, it produces the following result. Note how every single
special character has been converted to its printed form, right down to the last NEWLINE
at the end of the string between the "up." and closing triple quotes. Also note that
NEWLINEs occur either with an explicit carriage return at the end of a line or its escape
code (\n) −

this is a long string that is made up of


several lines and non-printable characters such as
TAB ( ) and they will show up that way when displayed.
NEWLINEs within the string, whether explicitly given like
this within the brackets [
], or just a NEWLINE within
the variable assignment will also show up.

Raw strings do not treat the backslash as a special character at all. Every character you
put into a raw string stays the way you wrote it −
 Live Demo
#!/usr/bin/python

print 'C:\\nowhere'

When the above code is executed, it produces the following result −

C:\nowhere

Now let's make use of raw string. We would put expression in r'expression' as follows −
#!/usr/bin/python  Live Demo

print r'C:\\nowhere'

When the above code is executed, it produces the following result −

C:\\nowhere

Unicode String
Normal strings in Python are stored internally as 8-bit ASCII, while Unicode strings are
stored as 16-bit Unicode. This allows for a more varied set of characters, including special
characters from most languages in the world. I'll restrict my treatment of Unicode strings
to the following −
 Live Demo
#!/usr/bin/python

print u'Hello, world!'

When the above code is executed, it produces the following result −

Hello, world!

As you can see, Unicode strings use the prefix u, just as raw strings use the prefix r.

Built-in String Methods


Python includes the following built-in methods to manipulate strings −

Sr.No. Methods with Description

capitalize()
1
Capitalizes first letter of string

center(width, fillchar)

2 Returns a space-padded string with the original string centered to a total of


width columns.

count(str, beg= 0,end=len(string))

3 Counts how many times str occurs in string or in a substring of string if starting
index beg and ending index end are given.

decode(encoding='UTF-8',errors='strict')

4 Decodes the string using the codec registered for encoding. encoding defaults
to the default string encoding.

5 encode(encoding='UTF-8',errors='strict')
Returns encoded string version of string; on error, default is to raise a
ValueError unless errors is given with 'ignore' or 'replace'.

endswith(suffix, beg=0, end=len(string))

6 Determines if string or a substring of string (if starting index beg and ending
index end are given) ends with suffix; returns true if so and false otherwise.

expandtabs(tabsize=8)

7 Expands tabs in string to multiple spaces; defaults to 8 spaces per tab if


tabsize not provided.

find(str, beg=0 end=len(string))

8 Determine if str occurs in string or in a substring of string if starting index beg


and ending index end are given returns index if found and -1 otherwise.

index(str, beg=0, end=len(string))


9
Same as find(), but raises an exception if str not found.

isalnum()

10 Returns true if string has at least 1 character and all characters are
alphanumeric and false otherwise.

isalpha()

11 Returns true if string has at least 1 character and all characters are alphabetic
and false otherwise.

isdigit()
12
Returns true if string contains only digits and false otherwise.

islower()

13 Returns true if string has at least 1 cased character and all cased characters
are in lowercase and false otherwise.

isnumeric()

14 Returns true if a unicode string contains only numeric characters and false
otherwise.

isspace()
15
Returns true if string contains only whitespace characters and false otherwise.

16 istitle()
Returns true if string is properly "titlecased" and false otherwise.

isupper()

17 Returns true if string has at least one cased character and all cased characters
are in uppercase and false otherwise.

join(seq)

18 Merges (concatenates) the string representations of elements in sequence seq


into a string, with separator string.

len(string)
19 Returns the length of the string

ljust(width[, fillchar])

20 Returns a space-padded string with the original string left-justified to a total of


width columns.

lower()
21
Converts all uppercase letters in string to lowercase.

lstrip()
22
Removes all leading whitespace in string.

maketrans()
23
Returns a translation table to be used in translate function.

max(str)
24 Returns the max alphabetical character from the string str.

min(str)
25
Returns the min alphabetical character from the string str.

replace(old, new [, max])

26 Replaces all occurrences of old in string with new or at most max occurrences if
max given.

rfind(str, beg=0,end=len(string))
27
Same as find(), but search backwards in string.

rindex( str, beg=0, end=len(string))


28
Same as index(), but search backwards in string.
29 rjust(width,[, fillchar])
Returns a space-padded string with the original string right-justified to a total
of width columns.

rstrip()
30
Removes all trailing whitespace of string.

split(str="", num=string.count(str))

31 Splits string according to delimiter str (space if not provided) and returns list of
substrings; split into at most num substrings if given.

splitlines( num=string.count('\n'))

32 Splits string at all (or num) NEWLINEs and returns a list of each line with
NEWLINEs removed.

startswith(str, beg=0,end=len(string))
Determines if string or a substring of string (if starting index beg and ending
33
index end are given) starts with substring str; returns true if so and false
otherwise.

strip([chars])
34 Performs both lstrip() and rstrip() on string.

swapcase()
35
Inverts case for all letters in string.

title()

36 Returns "titlecased" version of string, that is, all words begin with uppercase
and the rest are lowercase.

translate(table, deletechars="")

37 Translates string according to translation table str(256 chars), removing those


in the del string.

upper()
38
Converts lowercase letters in string to uppercase.

zfill (width)

39 Returns original string leftpadded with zeros to a total of width characters;


intended for numbers, zfill() retains any sign given (less one zero).
40 isdecimal()
Returns true if a unicode string contains only decimal characters and false
otherwise.

 Previous Page Next Page 

Advertisements

FAQ's Cookies Policy Contact


© Copyright 2018. All Rights Reserved.

Enter email for newsletter go

You might also like