a = [67, 5, 90, 20, 30]
b = ['Маша', 'Ваня', 'Лена', 'Марина', 'Арнольд']
print(a)
print(b)
aa = a[:] # Автономная копия списка
aaa = list(a) # Автономная копия списка
aaaa = a.copy() # Автономная копия списка
aaa.reverse() # Сортировка списка в обратном порядке
print(a[0]) # Первый элемент 67
print(a[2]) # Третий элемент 90
print(b[1]) # второй элемент Ваня
b.append('Дима') # Добавление элемента в конец списка
print(b[-1]) # Печать последнего элемента Дима
a.sort() # Сортировка списка
print(a) # [5, 20, 30, 67, 90]
print(aa) # [67, 5, 90, 20, 30]
print(aaa) # [30, 20, 90, 5, 67]
print(aaaa) # [67, 5, 90, 20, 30]
[67, 5, 90, 20, 30]
['Маша', 'Ваня', 'Лена', 'Марина', 'Арнольд']
67
90
Ваня
Дима
[5, 20, 30, 67, 90]
[67, 5, 90, 20, 30]
[30, 20, 90, 5, 67]
[67, 5, 90, 20, 30]
Так же как и список, кортеж (tuple) является упорядоченной последовательностью элементов. Вся разница заключается в том, что кортежи неизменяемы. Кортежи используются для защиты данных от перезаписи и обычно работают быстрее, чем списки, т.к. их нельзя изменять.
Для создания кортежа нужно поместить внутрь круглых скобок элементы, разделённые запятой:
t = (5, 'program', 1 + 3j)
print("t[0] =", t[0])
print("t[1] =", t[1])
print("t[2] =", t[2])
for i in t:
print(i, end=" – ")
t[0] = 5
t[1] = program
t[2] = (1+3j)
5 – program – (1+3j) –
Списки имеют большой набор функций:
• append , extend – добавление;
• insert – вставка;
• index – найти индекс первого вхождения конкретного элемента;
• count – подсчет повторов элемента;
• remove , del – удаление элемента;
• sort – сортировка;
• reverse – реверс;
• pop – извлечение элемента;
• len – длина списка;
• max – максимальный элемент;
• min – минимальный элемент;
• оператор in – проверка элемента на вхождение.
4.2 Словари
Структура данных, позволяющая идентифицировать ее элементы не по числовому индексу, а по произвольному, называется словарем или ассоциативным массивом. Соответствующая структура данных в языке Python 3 называется dict.
Каждый элемент словаря состоит из двух объектов: ключа и значения. В примере ниже ключом является название страны, а значением является название столицы. Ключ идентифицирует элемент словаря, значение является данными, которые соответствуют данному ключу. Значения ключей – уникальны, двух одинаковых ключей в словаре быть не может.
# Создадим пустой словарь Capitals
Capitals = dict()
# Заполним его несколькими значениями
Capitals['Russia'] = 'Moscow'
Capitals['Ukraine'] = 'Kiev'
Capitals['USA'] = 'Washington'
Countries = ['Russia', 'France', 'USA', 'Russia']
for country in Countries:
# Для каждой страны из списка проверим, есть ли она в словаре Capitals
if country in Capitals:
print('Столица страны ' + country + ': ' + Capitals[country])
else:
print('В базе нет страны c названием ' + country)
Столица страны Russia: Moscow
В базе нет страны c названием France
Столица страны USA: Washington
Столица страны Russia: Moscow
Методы словарей:
• clear() – очищает словарь;
• copy() – возвращает копию словаря;
• fromkeys(seq[, value]) – создает словарь с ключами из seq и значением value (по умолчанию None);
• get(key[, default]) – возвращает значение ключа, но если его нет, не бросает исключение, а возвращает default (по умолчанию None);
• items() – возвращает пары (ключ, значение);
• keys() – возвращает ключи в словаре;
• pop(key[, default]) – удаляет ключ и возвращает значение. Если ключа нет, возвращает default (по умолчанию бросает исключение);
• popitem() – удаляет и возвращает пару (ключ, значение). Если словарь пуст, бросает исключение KeyError. Помните, что словари неупорядочены;
• setdefault(key[, default]) – возвращает значение ключа, но если его нет, не бросает исключение, а создает ключ с значением default (по умолчанию None);
• update([other]) – обновляет словарь, добавляя пары (ключ, значение) из other. Существующие ключи перезаписываются. Возвращает None (не новый словарь!);
• values() – возвращает значения в словаре.
Countries = {'Russia': 'Moscow', 'Ukraine': 'Kiev', 'USA': 'Washington', 'Kazakhstan': 'Astana'}
print(Countries)
key1 = 'USA'
key2 = 'us'
if key1 in Countries:
del Countries[key1]
try:
del Countries[key2]
except KeyError:
print('Нет элемента с ключом "' + key2 + '" в словаре')
print(Countries)
{'Ukraine': 'Kiev', 'Russia': 'Moscow', 'Kazakhstan': 'Astana', 'USA': 'Washington'}
Нет элемента с ключом "us" в словаре
{'Ukraine': 'Kiev', 'Russia': 'Moscow', 'Kazakhstan': 'Astana'}
# Преобразование списка-кортеджа в словарь
users = (
("+111123455", "Tom"),
("+384767557", "Bob"),
("+958758767", "Alice")
)
users_dict = dict(users)
print(users)
print(users_dict)
# получаем элемент с ключом "+111123455"
print(users_dict["+111123455"]) # Tom
# установка значения элемента с ключом "+384767557"
users_dict["+384767557"] = "Bob Smith"
print(users_dict["+384767557"]) # Bob Smith
(('+111123455', 'Tom'), ('+384767557', 'Bob'), ('+958758767', 'Alice'))
{'+958758767': 'Alice', '+384767557': 'Bob', '+111123455': 'Tom'}
Tom
Bob Smith
4.2.1 Сортировка словарей
# Пример подсчета одинаковых символов в текстовом файле с использованием словаря
my_dict = dict()
my_text = open(u'D:/text.txt', 'r').read()
for c in my_text:
if c in my_dict:
my_dict[c] = my_dict[c] + 1
else:
my_dict.update({c: 1})
for w in sorted(my_dict, key=my_dict.get, reverse=True):
print(w, my_dict[w])
L 9
o 9
f 8
p 8
4.3 Циклы
mas = ['Ленин', 'Сталин', 'Хрущёв', 'Брежнев', 'Горбачёв', 'Путин']
mas.append('Медведев')
for x in mas:
print('правил ' + x + ' а после него… ')
a = 1
while (a < 5):
print(a, "^ 2 =", a * a, ' ', a ** 2)
a = a + 1