omz:forum

    • Register
    • Login
    • Search
    • Recent
    • Popular

    Welcome!

    This is the community forum for my apps Pythonista and Editorial.

    For individual support questions, you can also send an email. If you have a very short question or just want to say hello — I'm @olemoritz on Twitter.


    Python not wait for sub Function

    Pythonista
    3
    19
    3332
    Loading More Posts
    • Oldest to Newest
    • Newest to Oldest
    • Most Votes
    Reply
    • Reply as topic
    Log in to reply
    This topic has been deleted. Only users with topic management privileges can see it.
    • cvp
      cvp @DavinE last edited by

      @DavinE said:

      this has no effect :(

      Perhaps something in your self.setFileNamePDF has a callback and you could need to wait it is finished.

      1 Reply Last reply Reply Quote 0
      • DavinE
        DavinE last edited by

        @cvp
        callback ?

        in the Function is a return like this:

        return os.path.join(os.path.dirname(sys.argv[0]), 'Reportlab', materiallistFilesName)
        

        how can i wait till my function is finished that's my problem i don't know how

        1 Reply Last reply Reply Quote 0
        • DavinE
          DavinE @cvp last edited by

          @cvp said:

          @DavinE and what is the code of self.setFileNamePDF ?

          this is my complete self.setFileNamePDF:

          @ui.in_background
              def setFileNamePDF(self, customer, customer_project, materiallistType):
                  self.createLog(False, 'setFileNamePDF -- Aufruf der Funktion - Dateiname für die *.pdf Datei finden', '', 1)
                  
                  materiallistFilesName = None
                  self.Synology_DS718(customer)
                  try:
                      decontrol = None
                      for directory in self.connection_FTP.nlst(self.mainDirCustomer__CONFIG):
                          if directory.encode('latin-1').decode('utf-8') == self.subDirCustomer__CUSTOMER:
                              decontrol = True
                              break
                      if decontrol:
                          subDirCustomer_Materiallisten__CUSTOMER = '%s/%s' % (self.subDirCustomer_Materiallisten, customer_project)
                          subDirCustomer_Eintragungen = '%s/%s' % (subDirCustomer_Materiallisten__CUSTOMER, self.subDirCustomer_Eintragungen__CONFIG)
                          subDirCustomer_ZwischenRechnung = '%s/%s' % (subDirCustomer_Materiallisten__CUSTOMER, self.subDirCustomer_ZwischenRechnung__CONFIG)
                          subDirCustomer_Abgeschlossen = '%s/%s' % (subDirCustomer_Materiallisten__CUSTOMER, self.subDirCustomer_Abgeschlossen__CONFIG)
          
                          if materiallistType == self.subDirCustomer_Eintragungen__CONFIG:
                              materiallistType__Path = subDirCustomer_Eintragungen
                          elif materiallistType == self.subDirCustomer_ZwischenRechnung__CONFIG:
                              materiallistType__Path = subDirCustomer_ZwischenRechnung
                          elif materiallistType == self.subDirCustomer_Abgeschlossen__CONFIG:
                              materiallistType__Path = subDirCustomer_Abgeschlossen
                          else:
                              print(f'[ 7000 ] -- Der Materiallisten Typ konnte nicht ermittelt werden: [ {materiallistType} ]:\n{e}')
                              sound.play_effect(play_sound('play_effect', 'mysql', 'error'))
                              self.createLog(False, '[ 7000 ]', '', 2)
                              self.createLog(False, f'Der Materiallisten Typ konnte nicht ermittelt werden: [ {materiallistType} ]', '', 2)
                              console.alert('ftp-error', 'Der Materiallisten Typ konnte nicht ermittelt werden:\n[ {materiallistType} ]', hide_cancel_button=False)
          
                          if materiallistType == self.subDirCustomer_Abgeschlossen__CONFIG:
                              print("Abfrage drine!!")
                              materiallistFilesName =  f'{date.today()} -- {customer_project}.pdf'
                          else:
                              for i, files in enumerate(self.connection_FTP.nlst(materiallistType__Path)):
                                  for n in range(1, 51):
                                      if os.path.basename(files).encode('latin-1').decode('utf-8') == f'{date.today()}__{n} -- {customer_project}.pdf':
                                          materiallistFilesName = f'{date.today()}__{(n + 1)} -- {customer_project}.pdf'
                                  if (len(self.connection_FTP.nlst(materiallistType__Path)) - 1) is i:
                                      if not materiallistFilesName:
                                          materiallistFilesName =  f'{date.today()}__1 -- {customer_project}.pdf'
                                      break
                              else:
                                  materiallistFilesName = f'{date.today()}__1 -- {customer_project}.pdf'
                  except ftplib.all_errors as e:
                      print(f'[ 7001 ] -- Error bei der Funktion [ setFileNamePDF ]:\n{e}')
                      sound.play_effect(play_sound('play_effect', 'mysql', 'error'))
                      self.createLog(False, '[ 7001 ]', '', 2)
                      self.createLog(False, 'Error bei der Funktion [ setFileNamePDF ]', '', 2)
                      self.createLog(False, f'FTP-Server Fehler: {e}', '', 2)
                      console.alert('ftp-error', 'Kundenordner konnten nicht erstellt werden. [ Kunde Erstellen ]\nFehlerausgabe im Terminal', hide_cancel_button=False)
                  finally:
                      self.connection_FTP.quit()
                      
                  print(materiallistFilesName)
                  return os.path.join(os.path.dirname(sys.argv[0]), 'Reportlab', materiallistFilesName)
          
          cvp 1 Reply Last reply Reply Quote 0
          • cvp
            cvp @DavinE last edited by

            @DavinE is your @ui.in_background needed?

            1 Reply Last reply Reply Quote 0
            • DavinE
              DavinE last edited by

              @cvp, Honestly ? xD

              i have no idea why i set this....

              what does @ui.in_background and @on_main_thread exactly

              cvp 1 Reply Last reply Reply Quote 0
              • cvp
                cvp @DavinE last edited by

                @DavinE There are two base threads in Pythonista and you can force to run a process in The main_thread or in tHe ui one.
                Remove this line and it is still not ok, put the line @on_main_thread

                1 Reply Last reply Reply Quote 0
                • DavinE
                  DavinE last edited by

                  @cvp like this:

                  @on_main_thread
                  def generatePDF(...)
                  

                  and here:

                  def setFileNamePDF(self, customer, customer_project, materiallistType)
                  

                  nothing ?

                  cvp 1 Reply Last reply Reply Quote 0
                  • cvp
                    cvp @DavinE last edited by

                    @DavinE Sincerely, I don't know but personally I would put the @on_main_thread before the other def.

                    DavinE 1 Reply Last reply Reply Quote 0
                    • DavinE
                      DavinE last edited by

                      @cvp okay thanks i try it and response to you xD

                      1 Reply Last reply Reply Quote 0
                      • DavinE
                        DavinE @cvp last edited by

                        @cvp said:

                        @DavinE Sincerely, I don't know but personally I would put the @on_main_thread before the other def.

                        it works xD Thanks @cvp

                        cvp 1 Reply Last reply Reply Quote 0
                        • cvp
                          cvp @DavinE last edited by cvp

                          @DavinE eureka

                          1 Reply Last reply Reply Quote 0
                          • montykit
                            montykit last edited by

                            Hi everyone,

                            Is it possible to launch a python command without waiting for a return ? and therefore start the next command without waiting the previous one to finish ?

                            I searched and asked also on StackOverflow but so far I didn't found what I was looking for...

                            something that look promising might be the
                            1
                            concurrent.futures import ThreadPoolExecutor, ProcessPoolExecutor
                            as seen here -> https://stackoverflow.com/a/60832288/11943028

                            But this example is focus on results that I don't need. any ideas ?

                            Thank you.


                            https://fashionmentions.com/best-foundation/

                            DavinE cvp 3 Replies Last reply Reply Quote 0
                            • DavinE
                              DavinE @montykit last edited by

                              @montykit,

                              in my case @ui.in_backgroundworks... and don't wait for a return

                              maybe for you too

                              1 Reply Last reply Reply Quote 0
                              • cvp
                                cvp @montykit last edited by cvp

                                @montykit see the threading module, you could start one thread for each command

                                But what do you call a command?

                                1 Reply Last reply Reply Quote 0
                                • cvp
                                  cvp @montykit last edited by cvp

                                  @montykit try

                                  import threading
                                  
                                  class MyThread(threading.Thread):
                                  	def __init__(self,cmd):
                                  		threading.Thread.__init__(self)
                                  		self.run = cmd
                                  
                                  def cmd1():	
                                  	s = 0
                                  	for i in range(1000):
                                  		s += 1
                                  	print(s)
                                  	
                                  def cmd2():	
                                  	s = 0
                                  	for i in range(1000):
                                  		s += i
                                  	print(s)
                                  
                                  
                                  MyThread(cmd1).start()
                                  MyThread(cmd2).start()
                                  
                                  1 Reply Last reply Reply Quote 0
                                  • First post
                                    Last post
                                  Powered by NodeBB Forums | Contributors