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 question.(5)

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

ITtutoria

ITtutoria Logo ITtutoria Logo

ITtutoria Navigation

  • Python
  • Java
  • Reactjs
  • JavaScript
  • R
  • PySpark
  • MYSQL
  • Pandas
  • QA
  • C++
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Python
  • Science
  • Java
  • JavaScript
  • Reactjs
  • Nodejs
  • Tools
  • QA
Home/ Questions/How to fix oserror: [winerror 10038] an operation was attempted on something that is not a socket?
Next
Answered
Annabel Jacobi
  • 3
Annabel Jacobi
Asked: July 22, 20222022-07-22T10:08:02+00:00 2022-07-22T10:08:02+00:00In: Error

How to fix oserror: [winerror 10038] an operation was attempted on something that is not a socket?

  • 3

. Advertisement .

..3..

. Advertisement .

..4..

I got the warning “oserror: [winerror 10038] an operation was attempted on something that is not a socket” with my method impacted by the original code (version 9.76.01) below:

def run(self):
try:
buf = b""
while self.conn.isConnected():

data = self.conn.recvMsg()
logger.debug("reader loop, recvd size %d", len(data))
buf += data

while len(buf) > 0:
(size, msg, buf) = comm.read_msg(buf)
#logger.debug("resp %s", buf.decode('ascii'))
logger.debug("size:%d msg.size:%d msg:|%s| buf:%s|", size,
len(msg), buf, "|")

if msg:
self.msg_queue.put(msg)
else:
logger.debug("more incoming packet(s) are needed ")
break

logger.debug("EReader thread finished")
except:
logger.exception('unhandled exception in EReader thread')

I don’t know the reason that occurs this issue. Please help me fix it as soon as possible.

Thanks a lot. I really appreciate you guys’ support.

  • 1 1 Answer
  • 226 Views
  • 0 Followers
  • 0
Answer
Share
  • Facebook
  • Report

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Best Answer
    dttutoria Expert
    2022-07-22T10:23:24+00:00Added an answer on July 22, 2022 at 10:23 am

    The cause:

    On Windows Python, you get the error while executing InteractiveBrokers API’s disconnect():

    The Interactive Brokers API class has a mistake that is the cause of oserror: [winerror 10038] an operation was attempted on something that is not a socket problem.

    Solution: Change C:\TWS API\source\pythonclient\ibapi\reader.py and install new to resolve the issue and prevent an error from being unnecessarily raised:

    To resolve the issue, substitute this code:

    def run(self):
    try:
    buf = b""
    while self.conn.isConnected():
    
    try:
    data = self.conn.recvMsg()
    logger.debug("reader loop, recvd size %d", len(data))
    buf += data
    
    except OSError as err:
    #If connection is disconnected, Windows will generate error 10038
    if err.errno == 10038:
    
    #Wait up to 1 second for disconnect confirmation
    waitUntil = time.time() + 1
    while time.time() < waitUntil:
    if not self.conn.isConnected():
    break
    time.sleep(.1)
    
    if not self.conn.isConnected():
    logger.debug("Ignoring OSError: {0}".format(err))
    break
    
    #Disconnect wasn't received or error != 10038
    raise
    
    while len(buf) > 0:
    (size, msg, buf) = comm.read_msg(buf)
    #logger.debug("resp %s", buf.decode('ascii'))
    logger.debug("size:%d msg.size:%d msg:|%s| buf:%s|", size,
    len(msg), buf, "|")
    
    if msg:
    self.msg_queue.put(msg)
    else:
    logger.debug("more incoming packet(s) are needed ")
    break
    
    logger.debug("EReader thread finished")
    except:
    logger.exception('unhandled exception in EReader thread')
    • 3
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

Sidebar

Ask A Question
  • How to Split String by space in C++
  • How To Convert A Pandas DataFrame Column To A List
  • How to Replace Multiple Characters in A String in Python?
  • How To Remove Special Characters From String Python

Explore

  • Home
  • Tutorial

Footer

ITtutoria

ITtutoria

This website is user friendly and will facilitate transferring knowledge. It would be useful for a self-initiated learning process.

@ ITTutoria Co Ltd.

Tutorial

  • Home
  • Python
  • Science
  • Java
  • JavaScript
  • Reactjs
  • Nodejs
  • Tools
  • QA

Legal Stuff

  • About Us
  • Terms of Use
  • Privacy Policy
  • Contact Us

DMCA.com Protection Status

Help

  • Knowledge Base
  • Support

Follow

© 2022 Ittutoria. All Rights Reserved.

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.