Pull to refresh

Comments 58

в избранное. хорошая работа.
но "Dive Into Python" уже почитал чуть-чуть)))
так продолжайте. оно того стоит :)
жаль только перевод обрывается слишком рано...
так у меня образование переводчика есть... :) при чем основное...

я литературу, в основном, на английском и читаю)))
А не хотите доперевести, если время есть? ;)
хм... сейчас я имею несколько проектов. времени не очень то и есть свободного.
филолог то я украинский. я русский плоховато знаю. делаю очень много орфографических ошыбок. а если делать что-то, то делать качественно. :)
мужик, ты хоть на урк. переведи умаляю, братьев словян больше, переведуть =)
Уже одну утилитку для работы написал на питоне(или пайтоне?) после того, как ты начал писать о нем.

Спасибо, продолжай в том же духе!
не поверите! аж две. длинной в целых 17 и 21 строчку. так удобненько, просто нереально. только очень медленно получается

а если серьезно - я не уловил повода вашего сарказма.
Если серьезно, я не понял, о каком сарказме идет речь.

Я серьезно благодарен за статью и серьезно доволен скоростью написания небольших и не сложных программ.
прошу прощения. конкретный недосып делает свое злое дело :(
увидел сарказм там где его в помине не было.
просто мой парсер неправильно распарсил вашу фразу. еще раз извините.
Я вас понимаю :) Радуюсь тому моменту, что с сегодняшнего дня отпуск и вдоволь отосплюсь(мечта).
автор молодец, продолжай в том же духе!
спасибо
только сегодня делал на питоне парсер :)
правда меня доканал синтаксис вроде этого

dic = {}
dic['key1'] = {}
dic['key2'] = {}
dic['key1']['key3'] = 5
dic['key2']['key4'] = 6

явное обьявление словарем в строках 2-3 меня доканывает :) непривычно
ну нет в пайтоне РНР-style массивов :)
Можно чуть короче:
 dic = {'key1': {'key3':5}, 'key2': {'key4':6}}
нельзя короче по причине того что ключи формируются динамически
Это в моем конкретном случае просто невозможно.
Хотя с вашей формой записи согласен для заранее известной структуры словаря
> dic = {}
> dic['key1'] = {}
> dic['key2'] = {}
> dic['key1']['key3'] = 5
> dic['key2']['key4'] = 6

а разве на php есть реализация такого массива с заранее неизвестной структурой? )
$dic['key1']['key3'] = 5;
$dic['key2']['key4'] = 6;

оно?)
Насколько правильно делать так:
s={1:'one',2:'two'}
for i in s:
print i

Вместо использзования цикла
for i in s.keys():
print i
для класса dict определен метод __iter__ возвращающий итератор по ключам.
так что, принципиально ничем не отличается.
вполне правильно
как и так:
>>> for k, v in s.iteritems():
... print k, v
...
1 one
2 two


вообще, я думаю что наиболее правильно как раз использовать .iterkeys(), .itervalues() и .iteritems(), хотя это мое предположение

Создание с помощью списковых включений. В данном случае мы берем кубы всех нечетных чисел от 1 до 20. Опечатка - от 0 до 19.

это не опечатка, честно. это я стормозил. простите, сейчас поправлю.
в принципе, ниче так. правда, на мой взгляд, немного скучновато.
я бы еще настоятельно рекомендовал добавить сюда такие полезности как sorted, перегон из списка пар в словарь и наоборот, а также map/zip и т.п.
все будет, если не будет форсмажора :) но не сразу...
Написать программу, которая получив на входе произвольный список удалит из него все повторяющиеся элементы.

самый простой пример:

my_list = [1,2,3,4,1,2,6,9,2,3,8,4,5,76,2,5,6,7]
unique_list = list(set(my_list))
# [1, 2, 3, 4, 5, 6, 7, 8, 9, 76]
мне кажется, порядок элементов имеет значение...
ну скажем про порядок речи не шло. так что как первый вариант это подходит :)
хотя про функцию set речь не шла
но вариант сохраняющий порядок - остается на повестке дня :)))
как это можно сделать "в лоб":
s=[1,2,3,2,3,4,5,1,3,0]
c=[]
for i in s:
if i not in c:
c.append(i)
интересно почему такой вариант:

a = [1,2,3,4,1,2,6,9,2,3,8,4,5,76,2,5,6,7]
b = [ e for i,e in enumerate(a) if e not in a[i+1:] ]
print b

не сохраняет порядок? (хотя по идее должен).
у меня в результате [1, 9, 3, 8, 4, 76, 2, 5, 6, 7]
не должен. смотри, ты проверяешь первый элемент. он есть в хвосте и ты его пропускаешь.
тоесть ты оставляешь только последние вхождения уникальных элементов.
я сделал так:
[x for i, x in enumerate(l) if l.index(x) == i]
но это тоже жусть.
а можно расписать словами как расшифровывается эта конструкция ?:)
был бы очень признателен
ну, l.index(x) - возвращает индекс первого вхождения х в l.
enumerate(l) возвращает итератор, выдающий пары значений вида (i, l[i]), где i=0..len(l).
таким образом мы идем по списку l, получая из него по-очереди пары индекс-значение, и если индекс элемента совпадает с индексом его первого вхождения в l, то мы его оставляем в "результате".

синтаксис "списочных генераторов" я распишу позже...
да, конечно.

фактически, мы строим новый список, итерируя по старому: включаем новый элемент в список (левая часть, та что до оператора for) если выполнено некоторое условие (правая часть, та что if).

итак, enumerate возвращает список пар вида (индекс-елемента, значение-элемента). мы итерируем по нему и проверяем, если индекс текущего элемента равен индексу первого вхождения этого элемента в исходный список, дополняем новый список текущим элементом.
спасибо - меня просто смутил синтаксис
надеюсь cleg в след уроке обьяснит более подробно :)
куда ж он денется... :)
Вот так сохраняет и в прошлом случае тоже сохранял, только с конца.
a = [1,2,3,4,1,2,6,9,2,3,8,4,5,76,2,5,6,7]
b = [ e for i,e in enumerate(a) if e not in a[:i] ]
print b
всё, понял ошибку.
засиживаться после работы - вредно :)
родил решение в одну строчку, но получился жесткач какой-то... страшно показывать :)
мне уже стало интересно, покажите пожалуйста :)
написал выше. дублирую:
[x for i, x in enumerate(l) if l.index(x) == i]
Быть може так:
b=[a[i] for i in range(len(a)) if a[i] not in a[:i]]
(a - исходная последовательность)

Кто короче?
Тупой и банальный алгоритм, сохраняющий порядок :)
>>> my_list = [1,2,3,4,1,2,6,9,2,3,8,4,5,76,2,5,6,7]
>>> ulist = []
>>> for i in my_list:
... if i not in ulist:
... ulist.append(i)
...
>>> ulist
[1, 2, 3, 4, 6, 9, 8, 5, 76, 7]
это правильно но не элегантно - да и потребует дополнительного расхода памяти на больших обьемах данных.
в вашем варианте я бы лично добавил del из изначального массива елемента который мы прошли
либо переделал бы алгоритм без использования дополнительного массива
посмотрим :) тут самому пайтону еще чить и учить...
но конечно было бы неплохо. постараюсь в общем...
"В данном случае мы берем кубы всех нечетных чисел от 0 до 19."
...
"[1, 9, 25, 49, 81, 121, 169, 225, 289, 361]"
Но это квадраты, а не кубы. Поправьте, пожалуйста :)
ок. спасибо :( столько раз на рвоном месте ошибиться - непростительно для меня.
import urllib

urls = open(«urls.txt», «r»)

for url in urls.readlines():
#tab#outfile = open(url.rstrip()+«.htm», «w»)
#tab#outurl=urllib.urlopen(«http://»+url.rstrip())
#tab#for line in outurl.readlines():
#tab##tab#outfile.write(line)
#tab#outurl.close()
#tab#outfile.close()
ну в принципе тоже вариант :)

ЗЫ добавил кармы, по идее должны теперь работать у вас теги
ну, как минимуму сократить
outfile.write(outurl.read())

кстати — логичнее было бы назвать inurl — оно ж все-таки входящее :)
% — скажите пожалуйста что этот знак означает в Пиайтоне? В примере он указывается, а что делает не пойму ???
Подскажите как пользоваться count (x) для определения одинаковых элементов в строке?
Sign up to leave a comment.

Articles