Форум программистов, компьютерный форум, киберфорум
Python: Научные вычисления
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.75/4: Рейтинг темы: голосов - 4, средняя оценка - 4.75
0 / 0 / 0
Регистрация: 15.12.2014
Сообщений: 10

Оптимизировать код

14.11.2016, 16:09. Показов 841. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте!

Помогите оптимизировать код
data_samples состоит из 255 узлов, каждый узел это текст статьи

Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
data_list=[]
t0 = time()
err_list=[]
for data_str in data_samples:     
    result = []
    err=[]   
    tokenize=TweetTokenizer()
    plurals=tokenize.tokenize(data_str.decode("utf-8") )
    items = list(range(0, 100))
    l = len(plurals)
    leng = 0
    wnl = WordNetLemmatizer() 
    for word in plurals:
        if wnl.lemmatize(word, 'n') in words.words():
            result.append(word)
        else:
            err.append(word)
        
    data_list.append(' '.join(result))
    err_list.append(' '.join(err))
    k=0
    
    
print("done in %0.3fs." % (time() - t0))
print("OK...")
Вложенный цикл работает очень медленно

Python
1
2
3
4
5
for word in plurals:
        if wnl.lemmatize(word, 'n') in words.words():
            result.append(word)
        else:
            err.append(word)

Заранее спасибо!
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
14.11.2016, 16:09
Ответы с готовыми решениями:

Как можно оптимизировать код? Код считывает кол-во скобок
s = input() s = cheked = set() ans = 0 L = len(s) for l in range(L+1 if L % 2 else L, 1, -2): for i in range(L-l+1): ...

Как можно максимально оптимизировать данный код через логическое индексирование? Код полностью работает
header = data = , , , , , , , , , , , , ] import numpy as np def salary_info_purchased(data, gender=None, purchased=None): ...

Оптимизировать код
Как можно оптимизировать этот код, чтобы время выполнения было меньше? Во входном файле 'input.txt' первая строка - цифра, означающая...

1
431 / 302 / 90
Регистрация: 03.12.2015
Сообщений: 741
14.11.2016, 21:29
Цитата Сообщение от max314 Посмотреть сообщение
Вложенный цикл работает очень медленно
Трудно сказать насколько быстро работают и что возвращают wnl.lemmatize, words.words(), tokenize.tokenize. Скорее всего списки. Попробуйте превратить их в множества, операции in будут выполняться намного быстрее.

Python
1
2
3
4
5
6
words_set = set(words.words()) # вроде не изменяется можно вынести из цикла, заодно превратить в set
for word in set(plurals): # поиск по set()
        if wnl.lemmatize(word, 'n') in words_set: # используется words_set, вынесенный из цикла
            result.append(word)
        else:
            err.append(word)
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
14.11.2016, 21:29
Помогаю со студенческими работами здесь

Оптимизировать код
Вообщем разработал класс для работы со временем, но не в плане как часы (24 часа максимум и т.д), а скорее для подсчета времени. Нужно...

Оптимизировать код
Существует число N,не превосходящее 10^9.число можно разложить на множители N=B*C несколькими способами. Нужно найти и вывести минимально...

Оптимизировать код
вот сам код n = int(input()) chisla = kol = int(input()); for i in range(kol): zad = if (len(zad) == 2): ...

Требуется оптимизировать код
Всем, доброго времени суток. Вот наверстал такой код!)))) Вопрос следующий: в каком направлении теперь двигаться, для оптимизации...

Как оптимизировать код?
Школьнику Васе на лето учитель по литературе задал прочитать много художественных произведений. Как хороший ученик, Вася сходил в школьную...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь(не выше 3-го порядка) постоянного тока с элементами R, L, C, k(ключ), U, E, J. Программа находит переходные токи и напряжения на элементах схемы классическим методом(1 и 2 з-ны. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru