Форум программистов, компьютерный форум, киберфорум
Python для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.90/21: Рейтинг темы: голосов - 21, средняя оценка - 4.90
V7
1 / 1 / 1
Регистрация: 30.09.2013
Сообщений: 27

Как в разных потоках сделать последовательный вывод строк?

30.09.2013, 13:44. Показов 4106. Ответов 11
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Ошибка Print, при многопоточии:

Ну всем привет, загвостка вот в чём. Есть 100 потоков, они делают какую-то работу и постят результат через Print.
Вот в чём собстно проблем:

Код:
Python
1
print color("HEY - Some text ... :DDD blabla - "+strftime("%X", gmtime()),fg=85)
Кликните здесь для просмотра всего текста
Code
1
2
3
4
5
6
7
8
9
10
11
12
HEY - Some text ... : DDD blabla - 09:03:38
HEY - Some text ... : DDD blabla - 09:03:38
HEY - Some text ... : DDD blabla - 09:03:38
HEY - Some text ... : DDD blabla - 09:03:38
HEY - Some text ... : DDD blabla - 09:03:38
HEY - Some text ... : DDD blabla - 09:03:38
HEY - Some text ... : DDD blabla - 09:03:38HEY - Some text ... : DDD blabla - 09:03:38
HEY - Some text ... : DDD blabla - 09:03:38
 
HEY - Some text ... : DDD blabla - 09:03:38
HEY - Some text ... : DDD blabla - 09:03:38
HEY - Some text ... : DDD blabla - 09:03:38


Или картинка:

Так вопрос: как это исправить, чтоб был ровный резулт, или вообще, почему так выходит ?
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
30.09.2013, 13:44
Ответы с готовыми решениями:

Как сделать две формы, выполняющиеся в разных потоках.
Если упростить пример, то есть допустим метод, который создаёт вторую форму, и во время своего исполнения прогрессбар на форме №2 растёт. ...

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

Последовательный вывод товара. Как сделать вывод товара?
вот есть скрипт выбора элементов последовательно. демо $(function(){ var questions = $('#questions'); function...

11
4866 / 3288 / 468
Регистрация: 10.12.2008
Сообщений: 10,570
30.09.2013, 15:31
Цитата Сообщение от V7 Посмотреть сообщение
Так вопрос: как это исправить, чтоб был ровный резулт, или вообще, почему так выходит ?
выложи полный код
0
V7
1 / 1 / 1
Регистрация: 30.09.2013
Сообщений: 27
30.09.2013, 15:54  [ТС]
Весь код? Шутка D ?
Вот тот же, переделанный с меньшим функционалом ...
Проблема та же ... : (
Спасибо, если поможешь ! ...

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
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
import Queue
import threading
import time
import os
import sys
import string
import datetime
from time import gmtime, strftime
from colors import color
 
def restart_program():
    python = sys.executable
    os.execl(python, python, * sys.argv)
 
exitFlag = 0
 
print ("+-----------------------------------------------------------------------------------+")
print ("")
print color("Fake program for CyberForum.ru site. By V7 (c)",fg=12)
print ("Message printer :DD")
print ("")
message=raw_input( " Message: " )
conn=input( " Times: " )
threadss=input(" Threads: ")
print ("+-----------------------------------------------------------------------------------+")
def start():
 class myThread (threading.Thread):
    def __init__(self, threadID, name, q):
        threading.Thread.__init__(self)
        self.threadID = threadID
        self.name = name
        self.q = q
    def run(self):
       for i in range(1, conn+1):
        print1(self.name+" "+str(i),i)
#-------------------------------------------------------------------------+++
 queueLock = threading.Lock()
 workQueue = Queue.Queue(10)
 threads = []
 threadID = 1
#-------------------------------------------------------------------------+++
 for i in range(1, threadss+1):
    thread = myThread(threadID, i, workQueue)
    thread.start()
    threads.append(thread)
    threadID += 1
#-------------------------------------------------------------------------+++
 queueLock.acquire()
 queueLock.release()
#-------------------------------------------------------------------------+++
 while not workQueue.empty():
     pass
#-------------------------------------------------------------------------+++
 exitFlag = 1
#-------------------------------------------------------------------------+++
 for t in threads:
    t.join()
 print ("+-----------------------------------------------------------------------------------+")
#-------------------------------------------------------------------------+++##11,198
def Question():
    print color(" Started at "+strftime("%X")+", completed at "+strftime("%X"),fg=191)
    print("")
    answer = raw_input(" And what we gonna do? (m - Again; s - From beginning; n - exit): ")
    if answer.strip() in "m".split():
        print("")
        print ("+-----------------------------------------------------------------------------------+")
        start()
        Question()
    if answer.strip() in "s".split():
        restart_program()
#-------------------------------------------------------------------------+++
def print1(name,count2):
    try:
        print color(" Message - "+message+" ("+strftime("%X", gmtime())+")"+ " | Count: "+str(count2)+" of "+str(conn),fg=85) #49print color("HEY - Some text ... :DDD blabla - "+strftime("%X", gmtime()),fg=85)#
    except:
       print color(" Error",fg=11)
#-------------------------------------------------------------------------+++
start()
Question()
0
4866 / 3288 / 468
Регистрация: 10.12.2008
Сообщений: 10,570
30.09.2013, 16:20
Цитата Сообщение от V7 Посмотреть сообщение
Вот тот же, переделанный с меньшим функционалом ...
Цитата Сообщение от V7 Посмотреть сообщение
Python
9
from colors import color
не думаю, что он запустится, так как colors.py не входит в библиотеку

Цитата Сообщение от V7 Посмотреть сообщение
Python
17
print ("+--------
во втором питоне print - это оператор, а не функция, поэтому круглые скобки не используются

Цитата Сообщение от V7 Посмотреть сообщение
Python
26
27
def start():
 class myThread
отступы - везде по четыре пробела, чтобы не гадать, что к чему относится

зачем 37-ая строка и всё, что с ней связано ?
есть неблокирующая очередь в библиотеке

Цитата Сообщение от V7 Посмотреть сообщение
Python
64
    if answer.strip() in "m".split():
чего ? ты пытаешься букву разделить ?

не надо вперемешку всё писать, пиши функции сверху, а операторы снизу

Цитата Сообщение от V7 Посмотреть сообщение
Python
23
conn=input( " Times: " )
а если там не то будет введено, тоже будешь вычислять и сохранять ?
0
V7
1 / 1 / 1
Регистрация: 30.09.2013
Сообщений: 27
30.09.2013, 17:00  [ТС]
Да ... насчёт библиотеки ...
Всё работает установи её через pip ... я пишу в Линуксе ...

Добавлено через 2 минуты
Я прекрасно знаю синтаксис Python-а, это мой не первый изученный язык, но не пойму, почему иногда криво, а иногда чётко идёт print ...
Лучшеб помог бы, чем всякую чушь нести, про пробелы ...

Допустим, я тоже не понимаю, почему ты зашифровал Pacific Ocean во вкладке Адрес ...
0
4866 / 3288 / 468
Регистрация: 10.12.2008
Сообщений: 10,570
30.09.2013, 23:25
Цитата Сообщение от V7 Посмотреть сообщение
Да ... насчёт библиотеки ...
Всё работает установи её через pip ... я пишу в Линуксе ...
https://pypi.python.org/pypi?%3Aaction=search&term=colors&submit =search
там их десятки разных

Цитата Сообщение от V7 Посмотреть сообщение
почему иногда криво, а иногда чётко идёт print
я думаю, что ты неправильно сделал блокировки
а так как твой код нечитаем, потому что ты не знаешь про pep8, то я тебе и предложил его исправить сначала (привести в читаемое состояние), потому что пока что это просто мешанина какая-то

Цитата Сообщение от V7 Посмотреть сообщение
Лучшеб помог бы, чем всякую чушь нести, про пробелы ...
в питоне отступы имеют большое значение (семантику), поэтому их нужно писать чётко, чтобы нельзя было перепутать один блок с другим

Не по теме:

Цитата Сообщение от V7 Посмотреть сообщение
Допустим, я тоже не понимаю, почему ты зашифровал Pacific Ocean во вкладке Адрес ...
это не шифрование, а кодирование
если бы я это зашифровал, ты бы за всю жизнь не прочитал



Не по теме:

Цитата Сообщение от V7 Посмотреть сообщение
Я прекрасно знаю синтаксис Python-а, это мой не первый изученный язык
значит, ты ни одного языка не знаешь
для написания программ нужно ещё уметь составлять алгоритмы, язык в этом не поможет

2
V7
1 / 1 / 1
Регистрация: 30.09.2013
Сообщений: 27
02.10.2013, 14:25  [ТС]
Спасибо, помогли в другом форуме:

Ответ: Потоки между собой конфликтовали, тем самым некрасиво(не по очереди) постили сообщения.
Как исправить: создать отдельный поток, который постит сообщения:

Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
from threading import Thread
from Queue import Queue
from time import gmtime, strftime
 
def worker():
    while True:
        item = q.get()
        print item
        q.task_done()
 
q = Queue()
for i in range(1):
     t = Thread(target=worker)
     t.daemon = True
     t.start()
 
# ---- Somewhere in your threads
    q.put( color("HEY - Some text ... :DDD blabla - "+strftime("%X", gmtime()),fg=85) )
# -----
q.join()
Не по теме:

Не по теме:

На этом форуме, мне не помогли, оскорбили и снизили репутацию ...



Тема закрыта ...
0
V7
1 / 1 / 1
Регистрация: 30.09.2013
Сообщений: 27
05.10.2013, 00:12  [ТС]
Цитата Сообщение от accept Посмотреть сообщение
не думаю, что он запустится, так как colors.py не входит в библиотеку
Кстати через pip - установка той библиотеки, что использую я
Bash
1
sudo pip install ansicolors
0
4866 / 3288 / 468
Регистрация: 10.12.2008
Сообщений: 10,570
05.10.2013, 01:31
http://www.pip-installer.org/e... ip-install
Code
1
2
3
4
5
6
Install packages from:
 
    PyPI (and other indexes) using requirement specifiers.
    VCS project urls.
    Local project directories.
    Local or remote source archives.
https://pypi.python.org/pypi/ansicolors/1.0.2

обычно сразу с основного сайта ставлю в тот питон, который нужно (у меня их несколько)
0
V7
06.10.2013, 20:27  [ТС]

Не по теме:

Молодец : )

0
V7
1 / 1 / 1
Регистрация: 30.09.2013
Сообщений: 27
02.11.2014, 14:55  [ТС]
Сори accept, выскочило ...
0
411 / 330 / 42
Регистрация: 10.03.2010
Сообщений: 3,313
03.11.2014, 10:18
Не подскажете, где ясно и доступно описано использование многопоточности в Python?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
03.11.2014, 10:18
Помогаю со студенческими работами здесь

Как работать с CSocлet в разных потоках?
Доброго времени суток.У меня проблема - пишу клиент-серверную программу, и решил распоточить приложение чтоб при соединениях главное окно...

как использовать методы класса в разных потоках?
Пишу программу для обмена данными с usb hid устройством. Чтобы получать данные от устройства в любой момент и не вешать главное окно, решил...

Метод выполнить в 11 разных потоках, соответственно для разных входных массивов
Здравствуйте, начал потихоньку разбираться в многопоточном программирование и не могу до конца разобраться. Допустим есть некий метод в...

Циклы обработки сообщений разных форм в разных потоках
Здравствуйте! Подскажите как реализовать циклы обработки сообщений разных форм в разных потоках. У коде одной формы сделал так: ...

Как запустить метод класса одновременно в разных потоках?
Как запустить метод класса одновременно в разных потоках? Будет ли конфликт между ними, или создать несколько экз. класса и в каждом потоке...


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

Или воспользуйтесь поиском по форуму:
12
Ответ Создать тему
Новые блоги и статьи
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США. Нашел на реддите интересную статью под названием «Кто-нибудь знает, где получить бесплатный компьютер или. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru