Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 5941209
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 22, 20262026-05-22T16:04:40+00:00 2026-05-22T16:04:40+00:00

I have created a function timeout_func that will run an another function normally and

  • 0

I have created a function timeout_func that will run an another function normally and return its output, but if the function exceeds ‘secs’ it will return a string ‘failed’.
Basically, it’s a workaround to timeout a function which could run infinitely. (python 2.7 on windows) (Why do I need a workaround, why can’t I just make the function non-infinite? Because sometimes you just can’t do that, it’ called bugs in known processes ie: fd = os.open('/dev/ttyS0', os.O_RDWR)

Anyways, my timeout_func was inspired from help I received here:
kill a function after a certain time in windows

The problem with my code is that for some reason the do_this function is receiving 14 variables instead of one. I get the error msg when running it by double clicking the script or from python.exe. From IDLE you get no exception errors….
exception error message

However, if I change it to:

def do_this(bob, jim):
return bob, jim

It works just fine…

What’s going on here? It doesn’t like the 1 variable functions…?

import multiprocessing
import Queue


def wrapper(queue, func, func_args_tuple):
    result = func(*func_args_tuple)
    queue.put(result)
    queue.close()

def timeout_func(secs, func, func_args_tuple):
    queue = multiprocessing.Queue(1) # Maximum size is 1
    proc = multiprocessing.Process( target=wrapper, args=(queue, func, func_args_tuple) )
    proc.start()

    # Wait for TIMEOUT seconds
    try:
        result = queue.get(True, secs)
    except Queue.Empty:
        # Deal with lack of data somehow
        result = 'FAILED'
        print func_args_tuple
    finally:
        proc.terminate()

    return result


def do_this(bob):
    return bob

if __name__ == "__main__":
    print timeout_func( 10, do_this, ('i was returned') )
    x = raw_input('done')
  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-05-22T16:04:41+00:00Added an answer on May 22, 2026 at 4:04 pm

    ('i was returned') is not a tuple. It evaluates to a string, just like (3+2) evaluated to an integer..

    Calling do_this(*('i was returned')) passes each letter of the sequence 'i was returned' as a separate argument – the equivalent of:

    do_this('i', ' ', 'w', 'a', 's', ' ', 'r', 'e', 't', 'u', 'r', 'n', 'e', 'd')
    

    Use ('i was returned',) instead to force it to be a tuple (due to the trailing comma).

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

I have created a function that takes a SQL command and produces output that
I have created a function outside of $(document).ready() , but am still using jQuery
I have created a function in PHP that calls a webservice and parses through
in my data layer class I have created a function to manually refresh the
Hey, so I have created a function to check the DB for unique entries,
I have created a JS function which executes fine when it's included an the
i have created a module with this among others this function in it: <?php
we are trying to create a calendar function in python. we have created a
I have dialog created like this $('#add_error').click(function(e) { $('<div>') .load('/someaction/format/html/') .dialog({ title: 'Some title',
I have question concerning a function I created. I would like to show the

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.