Python словарь сделать строкой

Словари Python

Словарем в языке программирования Python называется неупорядоченный набор данных произвольного типа с доступом по ключу. Элементами такой коллекции выступают пары объектов, каждая из которых включает в себя ключ и значение. Для работы со словарями доступны функции, меняющие их содержимое и выполняющие различные операции над ними. Его можно конвертировать в другие типы данных, например, в строку.

Создание

Перед тем как начать работу со словарем, его нужно создать. Сделать это можно базовыми средствами языка, присвоив свободной переменной произвольное количество пар объектов. Элементы необходимо поместить в фигурные скобки, а между ключом и значением должен стоять символ двоеточия. Следующий пример демонстрирует создание словаря под именем a, который включает в себя ключи в виде чисел и значения в виде строк.

Вывести содержимое словаря можно стандартной функцией print, указав для нее в качестве аргумента нужный набор данных. Для заполнения словаря также используется метод dict, получающий произвольное количество пар ключей и значений. В таком случае быть ключом может только строка, как это показано в следующем примере кода.

a = dict(one = 1, two = 2, three = 3) print(a)

Как и в прошлый раз, функция print отображает содержимое словаря a. В данном случае имеется пары объектов, представленных также в виде чисел и строк.

Добавление элемента

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

Читайте также:  Python del line file

В приведенном выше коде применяется оператор присваивания, благодаря чему новая пара (4 : “four”) помещается в конец уже созданной ранее коллекции a.

Объединение словарей

В том случае, если возникла необходимость в перемещении данных из одного словаря в другой, стоит воспользоваться функцией объединения update. Вызвать ее нужно на объекте, который предполагается расширить новыми парами ключей и значений. Вот пример как в Python добавить в словарь словарь:

Результатом работы метода print станет вывод на экран обновленного содержимого словаря под названием a.

Удаление элемента

Если словарь содержит лишнюю информацию, от нее можно легко избавиться при помощи специальной операции del. Для ее выполнения необходимо указать имя коллекции, а также ключ в квадратных скобках. Следующий пример показывает удаление пары.

Так как операция получила ключ 3, в результате ее работы удалилось и значение three.

Получение размера

Функция len позволяет в любой момент определить текущее количество элементов словаря, если передать ей в качестве аргумента имя коллекции. В приведенном ниже примере метод print осуществляет вывод на экран размерность словаря a.

Стоит заметить, что функция len возвращает точное количество пар, но не объектов. В этом случае имеется словарь, который содержит в себе ровно 3 пары.

Перебор словаря

Произвести перебор элементов словаря можно несколькими способами, в зависимости от желаемой для получения информации о его содержимом.

Перебор элементов можно осуществить с целью получения для последующей обработки:

В данном примере показывается как вывести на экран все пары этой коллекции в формате ключ : значение. Для этого используется цикл for и функция items, работающая с элементами словаря.

a = for key, value in a.items(): print(key, ":", value) 1 : one 2 : two 3 : three

Чтобы получить только ключи, следует применить метод keys, вызывав его на словаре.

a = for key in a.keys(): print(key) 1 2 3

Аналогичным образом нужно поступить, чтобы вывести только значения словаря. Однако в таком случае в цикле for используется метод values.

a = for val in a.values(): print(val) one two three

В обоих случаях отображается только выбранная часть пары, ключ или значение.

Поиск

Проверить наличие определенного ключа можно при помощи операции in. Для этого достаточно вывести результат ее выполнения для словаря по имени a.

a = print(2 in a) print(4 in a) True False

Как можно заметить, проверка ключа 2 дала положительный результат (True). Во втором случае вывелось значение False, поскольку ключа 4 в словаре не обнаружено.

Сортировка

Средства языка дают возможность проводить в Python сортировку словаря по ключам и значениям, в зависимости от необходимости. В следующем примере имеется коллекция данных по имени a, в которой содержится информация в произвольном порядке. Ключами здесь выступают числа, а значениями являются строки. Сортировка осуществляется за счет импортированного модуля operator и встроенного метода itemgetter, получающего 0 или 1.

import operator a = b = sorted(a.items(), key = operator.itemgetter(0)) print(b) b = sorted(a.items(), key = operator.itemgetter(1)) print(b) [(1, 'one'), (2, 'two'), (3, 'three')] [(1, 'one'), (3, 'three'), (2, 'two')]

Как можно заметить, аргумент 0 позволяет отсортировать словарь по ключу, в то время как 1 дает возможность вывести его содержимое в алфавитном порядке значений.

Сравнение

Иногда нужно удостовериться, что два словаря содержат абсолютно одинаковые данные, либо узнать какая коллекция больше или меньше по размеру. В этом случае на помощь приходит метод cmp, получающий в качестве параметров два словаря.

a = b = c = print(cmp(a, b)) print(cmp(b, c)) print(cmp(a, c)) 1 -1 0

Приведенный код продемонстрировал выполнение метода cmp с трема комбинациями аргументов. Как видно из результатов выдачи, функция возвращает 1, если первый больше второго, -1, если наоборот и 0, когда данные полностью идентичны.

Копирование

Метод copy используется для копирования содержимого одного словаря в другой. Данный пример демонстрирует перенос ключей и значений из коллекции a в b.

Как можно заметить, порядок и содержимое всех пар было сохранено в новом наборе.

Очистка

Чтобы избавиться от всех элементов словаря, стоит вызвать для него функцию clear.

В результате получается абсолютно пустой набор данных.

Генератор словарей

Как и с другими наборами данных, производить заполнение словарей можно при помощи генераторов. В следующем примере демонстрируется создание числовых пар коллекции с использованием генератора словарей Python с методом range, получающего в качестве аргумента 5.

Таким образом, на выходе получается словарь a, включающий в себя ровно 5 пар. Ключами являются числа от 0 до 4, а значениями выступают их математические квадраты.

Конвертация в строку

Словарь можно очень легко преобразовать в строку для более удобной работы с цельным представлением его содержимого. Чтобы сделать это, потребуется функция str. Как можно видеть из результатов выполнения метода type, конвертация прошла успешно.

a = b = str(a) print(b) print(type(b))

Аналогичным образом происходит обратное преобразование строки Python в словарь. Важно, чтобы ее текстовое содержимое подходило по структуре под рассматриваемую коллекцию.

a = » b = eval(a) print(b) print(type(b))

Как видно из примера, метод eval конвертирует весь текст строки в новый словарь.

Вложенные

В Python словари могут быть вложенными, то есть выступать частью другого более крупного словаря. При помощи уже знакомых ранее фигурных скобок и двоеточий можно обозначить границы этого набора данных и указать программе пары ключей со значениями.

a = < "First": < 1: "one", 2: "two", 3: "three" >, "Second": < 4: "four", 5: "five" >> print(a) , 'Second': >

В примере, описанном выше, создается словарь a, включающий в себя два других словаря (First и Second). Те, в свою очередь, содержат несколько пар ключей и значений.

Резюме

Следующая таблица демонстрирует краткую сводку по всем рассмотренным методам для работы со словарями в Python 3. В таблице отображаются названия методов, а также информация о их назначении.

Название Назначение
update Объединение содержимого двух словарей в один
len Получение размера
items Возвращает пары (ключи и значения)
keys Возвращает ключи
values Возвращает значения
copy Копирует содержимое в другой словарь
clear Полная очистка всех элементов
eval Конвертация строки в словарь

Источник

Преобразование python dict в строку и обратно

Я пишу программу, которая хранит данные в объекте словаря, но эти данные должны быть сохранены в какой-то момент во время выполнения программы и загружены обратно в объект словаря при повторном запуске программы. Как преобразовать объект словаря в строку, которая может быть записана в файл и загружена обратно в объект словаря? Это, надеюсь, поддерживает словари, содержащие словари.

ОТВЕТЫ

Ответ 1

Модуль JSON является хорошим решением здесь. Он имеет преимущество перед pickle в том, что он производит только вывод простого текста, а также является кроссплатформенным и кросс-версией.

import json json.dumps(dict) 

Ответ 2

Если ваш словарь не слишком большой, возможно, str + eval может выполнить работу:

dict1 = > str1 = str(dict1) dict2 = eval(str1) print dict1==dict2 

Вы можете использовать ast.literal_eval вместо eval для дополнительной безопасности, если источник не доверен.

Ответ 3

import json # convert to string input = json.dumps() # load to dict my_dict = json.loads(input) 

Ответ 4

Просто получить сделку с json на python

# import built-in json lib import json # dict to str str_json = json.dumps() # str to dict dict_from_str_json = json.loads('') 

Ответ 5

Используйте модуль pickle , чтобы сохранить его на диске и загрузить позже.

Ответ 6

Почему бы не использовать Python 3 встроенных Аста библиотеки функций literal_eval. Лучше использовать literal_eval вместо eval

import ast str_of_dict = "" ast.literal_eval(str_of_dict) 

выдаст вывод как фактический словарь

И если вы хотите преобразовать словарь в строку, как насчет использования str() метода Python.

Это легко, как вам нравится.

Ответ 7

import codecs fout = codecs.open("xxx.json", "w", "utf-8") dict_to_json = json.dumps(,ensure_ascii=False,indent=2) fout.write(dict_to_json + '\n') 

Ответ 8

Я думаю, вам стоит подумать об использовании модуля shelve , который предоставляет постоянные поддерживаемые файлом словарные объекты. Он прост в использовании вместо «реального» словаря, потому что он почти прозрачно предоставляет вашей программе что-то, что можно использовать точно так же, как словарь, без необходимости явно преобразовывать его в строку и затем записывать в файл (или вице- Versa).

Основное отличие состоит в том, чтобы сначала использовать open() его перед первым использованием, а затем close() его, когда вы закончите (и, возможно, sync() его, в зависимости от используемой опции writeback ). Любые создаваемые файловые объекты «полки» могут содержать регулярные словари в качестве значений, позволяя им быть логически вложенными.

import shelve shelf = shelve.open('mydata') # open for reading and writing, creating if nec shelf.update(>) shelf.close() shelf = shelve.open('mydata') print shelf shelf.close() 

Ответ 9

Я использую yaml для этого, если его нужно читать (ни JSON, ни XML не являются IMHO), или если чтение не нужно, я использую pickle.

from pickle import dumps, loads x = dict(a=1, b=2) y = dict(c = x, z=3) res = dumps(y) open('/var/tmp/dump.txt', 'w').write(res) 
from pickle import dumps, loads rev = loads(open('/var/tmp/dump.txt').read()) print rev 

Ответ 10

Преобразовать словарь в JSON (строка)

import json mydict = < "name" : "Don", "surname" : "Mandol", "age" : 43>result = json.dumps(mydict) print(result[0:20]) 

Конвертировать строку в словарь

back_to_mydict = json.loads(result) 

Ответ 11

Если вам нужна скорость, используйте ujson (UltraJSON), который имеет тот же API, что и json:

import ujson ujson.dumps([, 81, True]) # '[,81,true]' ujson.loads("""[, 81, true]""") # [, 81, True] 

Ответ 12

используйте обычные методы, а не библиотеки, которые просты , Это сработало для меня

dict = d=" " for i in dict: a=i b=dict[i] c=i+":"+dict[i] d=d+c+'\n' print d 

Источник

Оцените статью