Private Proxies – Buy Cheap Private Elite USA Proxy + 50% Discount!Private Proxies – Buy Cheap Private Elite USA Proxy + 50% Discount!Private Proxies – Buy Cheap Private Elite USA Proxy + 50% Discount!Private Proxies – Buy Cheap Private Elite USA Proxy + 50% Discount!
    0
  •   was successfully added to your cart.
  • Home
  • Buy proxies
  • Extra features
  • Help
  • Contact
  • Login
  • 50% OFF
    BUY NOW!
    50
    PROXIES
    $19
    --------------------
    BUY NOW!
    BUY NOW!
    BUY NOW!
    BUY NOW!
    BUY NOW!
    $29
    $49
    $109
    $179
    $299
    --------------------
    --------------------
    --------------------
    --------------------
    --------------------
    PROXIES
    PROXIES
    PROXIES
    PROXIES
    PROXIES
    100
    200
    500
    1,000
    2,000
    TOP SELLER
    BEST VALUE
    For All Private Proxies!

I’m new to programming in python, and I have a task to try and create continuous Queue but with Delay support. I haven’t added the threading or sharing the data q across threads yet but I still need the functionality for managing the delay.

With the examples I’ve seen using the queue class directly, it seems like I should be able to create a much more compact class than what I have written, but I wanted to see if someone could help pare this down to a more optimal class for managing. What I have here works, but hoping to be a bit more pythonic.

I’d really love it if someone could point out areas where I could be more efficient.

Here’s what I wrote so far:

import multiprocessing, requests import copy import time import pprint from enum import Enum from queue import Queue  from datetime import datetime, timedelta from multiprocessing import Pool  class QueueState(Enum):     Inactive = 0     Sleeping = 1     Processing = 2  class DelayQueue:      def __init__(self):         self.state = QueueState.Inactive         self.queue = []      def run(self):         while True:             currentwork = [item for item in self.queue if item.time <= datetime.now()]             currentwork.sort(key=lambda x: x.time, reverse=False)              print(len(currentwork), 'tasks ready for processing')             #Process the currentwork             for i, task in list(enumerate(currentwork)):                 if i == 0:                     print('Processing currentwork')                  print('Processing item', i)                 if task.process() == True:                     currentwork.remove(task)                     self.queue.remove(task)              print('Processing current tasks complete')             #No work ready yet             if len(currentwork) == 0 and len(self.queue) > 0:                 print("No work ready to process")              if len(self.queue) == 0:                 print('Queue empty closing queue')                 self.state = QueueState.Inactive                 break             elif len(currentwork) == 0:                 self.queue.sort(key=lambda x: x.time, reverse=False)                 nexttask = self.queue[0]                 print("Getting next task", nexttask)                 delta =  nexttask.time - datetime.now()                 print('Sleeping', delta.total_seconds(), 'seconds')                 self.state = QueueState.Sleeping                 if delta.total_seconds() > 0:                     time.sleep(delta.total_seconds())      def add(self, func, delay=0, **kwargs):         self.queue.append(Task(func, datetime.now() + timedelta(milliseconds=delay), **kwargs))         #if self.state == QueueState.Inactive:         #self.run()      def remove():         raise NotImplementedError  class Task:     def __init__(self, func, time, **kwargs):         print("New task", (func.__name__, time, kwargs))         self.func = func         self.time = time         self.args = kwargs      def process(self):         self.func(**self.args)         return True     def __str__(self):         return str((self.func.__name__, self.time, self.args))  def get(**kwargs):     url = kwargs['url']     print('Requesting', url)     r = requests.get(url=url)     print("Status Code", r.status_code)   queue = DelayQueue()  queue.add(get, 1500, url='http://www.google.com') queue.add(get, 4300, url='http://www.yahoo.com') queue.add(get, 3900, url='http://www.att.com') queue.add(get, 2500, url='http://www.nbc.com') queue.add(get, 2450, url='http://www.msn.com') queue.add(get, 2450, url='http://www.gmail.com')  queue.run() 

Output:

New task ('get', datetime.datetime(2018, 1, 19, 17, 18, 51, 843225), {'url': 'http://www.google.com'}) New task ('get', datetime.datetime(2018, 1, 19, 17, 18, 54, 643616), {'url': 'http://www.yahoo.com'}) New task ('get', datetime.datetime(2018, 1, 19, 17, 18, 54, 243917), {'url': 'http://www.att.com'}) New task ('get', datetime.datetime(2018, 1, 19, 17, 18, 52, 844260), {'url': 'http://www.nbc.com'}) New task ('get', datetime.datetime(2018, 1, 19, 17, 18, 52, 794472), {'url': 'http://www.msn.com'}) New task ('get', datetime.datetime(2018, 1, 19, 17, 18, 52, 794630), {'url': 'http://www.gmail.com'}) 0 tasks ready for processing Processing current tasks complete No work ready to process Getting next task ('get', datetime.datetime(2018, 1, 19, 17, 18, 51, 843225), {'url': 'http://www.google.com'}) Sleeping 1.498037 seconds 1 tasks ready for processing Processing currentwork Processing item 0 Requesting http://www.google.com Status Code 200 Processing current tasks complete No work ready to process Getting next task ('get', datetime.datetime(2018, 1, 19, 17, 18, 52, 794472), {'url': 'http://www.msn.com'}) Sleeping 0.820134 seconds 2 tasks ready for processing Processing currentwork Processing item 0 Requesting http://www.msn.com Status Code 200 Processing item 1 Requesting http://www.gmail.com Status Code 200 Processing current tasks complete No work ready to process Getting next task ('get', datetime.datetime(2018, 1, 19, 17, 18, 52, 844260), {'url': 'http://www.nbc.com'}) Sleeping -0.540612 seconds 1 tasks ready for processing Processing currentwork Processing item 0 Requesting http://www.nbc.com Status Code 200 Processing current tasks complete No work ready to process Getting next task ('get', datetime.datetime(2018, 1, 19, 17, 18, 54, 243917), {'url': 'http://www.att.com'}) Sleeping 0.708722 seconds 1 tasks ready for processing Processing currentwork Processing item 0 Requesting http://www.att.com Status Code 200 Processing current tasks complete No work ready to process Getting next task ('get', datetime.datetime(2018, 1, 19, 17, 18, 54, 643616), {'url': 'http://www.yahoo.com'}) Sleeping 0.143595 seconds 1 tasks ready for processing Processing currentwork Processing item 0 Requesting http://www.yahoo.com Status Code 200 Processing current tasks complete Queue empty closing queue 

✓ Extra quality

ExtraProxies brings the best proxy quality for you with our private and reliable proxies

✓ Extra anonymity

Top level of anonymity and 100% safe proxies – this is what you get with every proxy package

✓ Extra speed

1,ooo mb/s proxy servers speed – we are way better than others – just enjoy our proxies!

50 proxies

$19/month

50% DISCOUNT!
$0.38 per proxy
✓ Private
✓ Elite
✓ Anonymous
Buy now

100 proxies

$29/month

50% DISCOUNT!
$0.29 per proxy
✓ Private
✓ Elite
✓ Anonymous
Buy now

200 proxies

$49/month

50% DISCOUNT!
$0.25 per proxy
✓ Private
✓ Elite
✓ Anonymous
Buy now

500 proxies

$109/month

50% DISCOUNT!
$0.22 per proxy
✓ Private
✓ Elite
✓ Anonymous
Buy now

1,000 proxies

$179/month

50% DISCOUNT!
$0.18 per proxy
✓ Private
✓ Elite
✓ Anonymous
Buy now

2,000 proxies

$299/month

50% DISCOUNT!
$0.15 per proxy
✓ Private
✓ Elite
✓ Anonymous
Buy now

USA proxy location

We offer premium quality USA private proxies – the most essential proxies you can ever want from USA

100% anonymous

Our proxies have TOP level of anonymity + Elite quality, so you are always safe and secure with your proxies

Unlimited bandwidth

Use your proxies as much as you want – we have no limits for data transfer and bandwidth, unlimited usage!

Superfast speed

Superb fast proxy servers with 1,000 mb/s speed – sit back and enjoy your lightning fast private proxies!

99,9% servers uptime

Alive and working proxies all the time – we are taking care of our servers so you can use them without any problems

No usage restrictions

You have freedom to use your proxies with every software, browser or website you want without restrictions

Perfect for SEO

We are 100% friendly with all SEO tasks as well as internet marketing – feel the power with our proxies

Big discounts

Buy more proxies and get better price – we offer various proxy packages with great deals and discounts

Premium support

We are working 24/7 to bring the best proxy experience for you – we are glad to help and assist you!

Satisfaction guarantee

24/7 premium support, free proxy activation and 100% safe payments! Best reliability private proxies for your needs!

Best Proxy Packs

  • 2,000 Private Proxies $600.00 $299.00 / month
  • 1,000 Private Proxies $360.00 $179.00 / month

Quick Links

  • More information
  • Contact us
  • Privacy Policy
  • Terms and Conditions

Like And Follow Us


Copyright ExtraProxies.com | All Rights Reserved.
  • Checkout
  • Contact
  • Help
  • Home
  • My Account
  • My Cart
  • News
  • Privacy Policy
  • Proxy features
  • Proxy packs
  • Terms and Conditions
Private Proxies – Buy Cheap Private Elite USA Proxy + 50% Discount!
    0 items