Watching something be piped to a file live with tailHow to continue running a program inspite of killing the shell which invoked itLinux terminal, my program only resumes after scrolling the printoutIs there a command in Linux which waits till it will be terminated?Ctrl+c in a sub process is killing a nohup'ed process earlier in the scriptCtrl-C'd an in-place recursive gzip - is this likely to have broken anything?Getting output of another script while preserving line-breakssocat and rich terminal againScript executed as other user from root creates files in wrong directory (root)Dealing with Ctrl+Z in UnixHow to pass Ctrl+C to script called from batch job

Detention in 1997

Can I run a new neutral wire to repair a broken circuit?

What are some good books on Machine Learning and AI like Krugman, Wells and Graddy's "Essentials of Economics"

Why was the shrinking from 8″ made only to 5.25″ and not smaller (4″ or less)?

Arrow those variables!

Mathematica command that allows it to read my intentions

How to tell a function to use the default argument values?

Why are the 737's rear doors unusable in a water landing?

Expand and Contract

What do you call someone who asks many questions?

A category-like structure without composition?

Why didn't Miles's spider sense work before?

One verb to replace 'be a member of' a club

Forgetting the musical notes while performing in concert

Little known, relatively unlikely, but scientifically plausible, apocalyptic (or near apocalyptic) events

ssTTsSTtRrriinInnnnNNNIiinngg

Do UK voters know if their MP will be the Speaker of the House?

Venezuelan girlfriend wants to travel the USA to be with me. What is the process?

How dangerous is XSS?

How do I deal with an unproductive colleague in a small company?

Is there a hemisphere-neutral way of specifying a season?

What is the most common color to indicate the input-field is disabled?

Avoiding direct proof while writing proof by induction

What about the virus in 12 Monkeys?



Watching something be piped to a file live with tail


How to continue running a program inspite of killing the shell which invoked itLinux terminal, my program only resumes after scrolling the printoutIs there a command in Linux which waits till it will be terminated?Ctrl+c in a sub process is killing a nohup'ed process earlier in the scriptCtrl-C'd an in-place recursive gzip - is this likely to have broken anything?Getting output of another script while preserving line-breakssocat and rich terminal againScript executed as other user from root creates files in wrong directory (root)Dealing with Ctrl+Z in UnixHow to pass Ctrl+C to script called from batch job













2















I have a python program which is, slowly, generating some output.



I want to capture that in a file, but I also thought I could watch it live with tail.



So in one terminal I'm doing :



python myprog.py > output.txt


and in another terminal :



tail -f output.txt


But it seems like the tail isn't showing me anything while the python program is running. If I hit ctrl-c to kill the python script, suddenly the tail of output.txt starts filling up. But not while the python is running.



What am I doing wrong?










share|improve this question

















  • 2





    How about python myprog.py | tee output.txt instead?

    – n8te
    4 hours ago











  • @n8te tee might show the same problem if the program isn't flushing the output buffer regularly. This needs flush() and tee.

    – JPhi1618
    1 hour ago











  • @JPhi1618 - you could be right but I just tested it with 800MB of data output and it didn't skip a beat.

    – n8te
    47 mins ago















2















I have a python program which is, slowly, generating some output.



I want to capture that in a file, but I also thought I could watch it live with tail.



So in one terminal I'm doing :



python myprog.py > output.txt


and in another terminal :



tail -f output.txt


But it seems like the tail isn't showing me anything while the python program is running. If I hit ctrl-c to kill the python script, suddenly the tail of output.txt starts filling up. But not while the python is running.



What am I doing wrong?










share|improve this question

















  • 2





    How about python myprog.py | tee output.txt instead?

    – n8te
    4 hours ago











  • @n8te tee might show the same problem if the program isn't flushing the output buffer regularly. This needs flush() and tee.

    – JPhi1618
    1 hour ago











  • @JPhi1618 - you could be right but I just tested it with 800MB of data output and it didn't skip a beat.

    – n8te
    47 mins ago













2












2








2








I have a python program which is, slowly, generating some output.



I want to capture that in a file, but I also thought I could watch it live with tail.



So in one terminal I'm doing :



python myprog.py > output.txt


and in another terminal :



tail -f output.txt


But it seems like the tail isn't showing me anything while the python program is running. If I hit ctrl-c to kill the python script, suddenly the tail of output.txt starts filling up. But not while the python is running.



What am I doing wrong?










share|improve this question














I have a python program which is, slowly, generating some output.



I want to capture that in a file, but I also thought I could watch it live with tail.



So in one terminal I'm doing :



python myprog.py > output.txt


and in another terminal :



tail -f output.txt


But it seems like the tail isn't showing me anything while the python program is running. If I hit ctrl-c to kill the python script, suddenly the tail of output.txt starts filling up. But not while the python is running.



What am I doing wrong?







linux command-line pipe






share|improve this question













share|improve this question











share|improve this question




share|improve this question










asked 4 hours ago









interstarinterstar

320311




320311







  • 2





    How about python myprog.py | tee output.txt instead?

    – n8te
    4 hours ago











  • @n8te tee might show the same problem if the program isn't flushing the output buffer regularly. This needs flush() and tee.

    – JPhi1618
    1 hour ago











  • @JPhi1618 - you could be right but I just tested it with 800MB of data output and it didn't skip a beat.

    – n8te
    47 mins ago












  • 2





    How about python myprog.py | tee output.txt instead?

    – n8te
    4 hours ago











  • @n8te tee might show the same problem if the program isn't flushing the output buffer regularly. This needs flush() and tee.

    – JPhi1618
    1 hour ago











  • @JPhi1618 - you could be right but I just tested it with 800MB of data output and it didn't skip a beat.

    – n8te
    47 mins ago







2




2





How about python myprog.py | tee output.txt instead?

– n8te
4 hours ago





How about python myprog.py | tee output.txt instead?

– n8te
4 hours ago













@n8te tee might show the same problem if the program isn't flushing the output buffer regularly. This needs flush() and tee.

– JPhi1618
1 hour ago





@n8te tee might show the same problem if the program isn't flushing the output buffer regularly. This needs flush() and tee.

– JPhi1618
1 hour ago













@JPhi1618 - you could be right but I just tested it with 800MB of data output and it didn't skip a beat.

– n8te
47 mins ago





@JPhi1618 - you could be right but I just tested it with 800MB of data output and it didn't skip a beat.

– n8te
47 mins ago










2 Answers
2






active

oldest

votes


















3














You may also need to explicitly flush the buffer for it to get piped upon generation. This is because output is typically only printed when the pipe's buffer fills up (which is in kilobytes I belive), and when the stdin message ends. This is probably to save on read/writes. You could do this after every print, or if you are looping, after the last print within the loop.



import sys
...
print('Some message')
sys.stdout.flush()






share|improve this answer








New contributor




Davey is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.



























    4














    Instead of trying to tail a live file, use tee instead. It was made to do exactly what you're trying to do.



    From man tee:




    tee(1) - Linux man page



    Name tee - read from standard input and write to standard output and files



    Synopsis



    tee [OPTION]... [FILE]...


    Description



    Copy standard input to each FILE, and also to standard output.



    -a, --append 
    append to the given FILEs, do not overwrite
    -i, --ignore-interrupts
    ignore interrupt signals
    --help
    display this help and exit
    --version
    output version information and exit


    If a FILE is -, copy again to standard output.




    So in your case you'd run:



    python myprog.py | tee output.txt





    share|improve this answer























      Your Answer








      StackExchange.ready(function()
      var channelOptions =
      tags: "".split(" "),
      id: "3"
      ;
      initTagRenderer("".split(" "), "".split(" "), channelOptions);

      StackExchange.using("externalEditor", function()
      // Have to fire editor after snippets, if snippets enabled
      if (StackExchange.settings.snippets.snippetsEnabled)
      StackExchange.using("snippets", function()
      createEditor();
      );

      else
      createEditor();

      );

      function createEditor()
      StackExchange.prepareEditor(
      heartbeatType: 'answer',
      autoActivateHeartbeat: false,
      convertImagesToLinks: true,
      noModals: true,
      showLowRepImageUploadWarning: true,
      reputationToPostImages: 10,
      bindNavPrevention: true,
      postfix: "",
      imageUploader:
      brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
      contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
      allowUrls: true
      ,
      onDemand: true,
      discardSelector: ".discard-answer"
      ,immediatelyShowMarkdownHelp:true
      );



      );













      draft saved

      draft discarded


















      StackExchange.ready(
      function ()
      StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fsuperuser.com%2fquestions%2f1421123%2fwatching-something-be-piped-to-a-file-live-with-tail%23new-answer', 'question_page');

      );

      Post as a guest















      Required, but never shown

























      2 Answers
      2






      active

      oldest

      votes








      2 Answers
      2






      active

      oldest

      votes









      active

      oldest

      votes






      active

      oldest

      votes









      3














      You may also need to explicitly flush the buffer for it to get piped upon generation. This is because output is typically only printed when the pipe's buffer fills up (which is in kilobytes I belive), and when the stdin message ends. This is probably to save on read/writes. You could do this after every print, or if you are looping, after the last print within the loop.



      import sys
      ...
      print('Some message')
      sys.stdout.flush()






      share|improve this answer








      New contributor




      Davey is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.
























        3














        You may also need to explicitly flush the buffer for it to get piped upon generation. This is because output is typically only printed when the pipe's buffer fills up (which is in kilobytes I belive), and when the stdin message ends. This is probably to save on read/writes. You could do this after every print, or if you are looping, after the last print within the loop.



        import sys
        ...
        print('Some message')
        sys.stdout.flush()






        share|improve this answer








        New contributor




        Davey is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
        Check out our Code of Conduct.






















          3












          3








          3







          You may also need to explicitly flush the buffer for it to get piped upon generation. This is because output is typically only printed when the pipe's buffer fills up (which is in kilobytes I belive), and when the stdin message ends. This is probably to save on read/writes. You could do this after every print, or if you are looping, after the last print within the loop.



          import sys
          ...
          print('Some message')
          sys.stdout.flush()






          share|improve this answer








          New contributor




          Davey is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
          Check out our Code of Conduct.










          You may also need to explicitly flush the buffer for it to get piped upon generation. This is because output is typically only printed when the pipe's buffer fills up (which is in kilobytes I belive), and when the stdin message ends. This is probably to save on read/writes. You could do this after every print, or if you are looping, after the last print within the loop.



          import sys
          ...
          print('Some message')
          sys.stdout.flush()







          share|improve this answer








          New contributor




          Davey is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
          Check out our Code of Conduct.









          share|improve this answer



          share|improve this answer






          New contributor




          Davey is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
          Check out our Code of Conduct.









          answered 3 hours ago









          DaveyDavey

          461




          461




          New contributor




          Davey is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
          Check out our Code of Conduct.





          New contributor





          Davey is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
          Check out our Code of Conduct.






          Davey is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
          Check out our Code of Conduct.























              4














              Instead of trying to tail a live file, use tee instead. It was made to do exactly what you're trying to do.



              From man tee:




              tee(1) - Linux man page



              Name tee - read from standard input and write to standard output and files



              Synopsis



              tee [OPTION]... [FILE]...


              Description



              Copy standard input to each FILE, and also to standard output.



              -a, --append 
              append to the given FILEs, do not overwrite
              -i, --ignore-interrupts
              ignore interrupt signals
              --help
              display this help and exit
              --version
              output version information and exit


              If a FILE is -, copy again to standard output.




              So in your case you'd run:



              python myprog.py | tee output.txt





              share|improve this answer



























                4














                Instead of trying to tail a live file, use tee instead. It was made to do exactly what you're trying to do.



                From man tee:




                tee(1) - Linux man page



                Name tee - read from standard input and write to standard output and files



                Synopsis



                tee [OPTION]... [FILE]...


                Description



                Copy standard input to each FILE, and also to standard output.



                -a, --append 
                append to the given FILEs, do not overwrite
                -i, --ignore-interrupts
                ignore interrupt signals
                --help
                display this help and exit
                --version
                output version information and exit


                If a FILE is -, copy again to standard output.




                So in your case you'd run:



                python myprog.py | tee output.txt





                share|improve this answer

























                  4












                  4








                  4







                  Instead of trying to tail a live file, use tee instead. It was made to do exactly what you're trying to do.



                  From man tee:




                  tee(1) - Linux man page



                  Name tee - read from standard input and write to standard output and files



                  Synopsis



                  tee [OPTION]... [FILE]...


                  Description



                  Copy standard input to each FILE, and also to standard output.



                  -a, --append 
                  append to the given FILEs, do not overwrite
                  -i, --ignore-interrupts
                  ignore interrupt signals
                  --help
                  display this help and exit
                  --version
                  output version information and exit


                  If a FILE is -, copy again to standard output.




                  So in your case you'd run:



                  python myprog.py | tee output.txt





                  share|improve this answer













                  Instead of trying to tail a live file, use tee instead. It was made to do exactly what you're trying to do.



                  From man tee:




                  tee(1) - Linux man page



                  Name tee - read from standard input and write to standard output and files



                  Synopsis



                  tee [OPTION]... [FILE]...


                  Description



                  Copy standard input to each FILE, and also to standard output.



                  -a, --append 
                  append to the given FILEs, do not overwrite
                  -i, --ignore-interrupts
                  ignore interrupt signals
                  --help
                  display this help and exit
                  --version
                  output version information and exit


                  If a FILE is -, copy again to standard output.




                  So in your case you'd run:



                  python myprog.py | tee output.txt






                  share|improve this answer












                  share|improve this answer



                  share|improve this answer










                  answered 3 hours ago









                  n8ten8te

                  5,18272234




                  5,18272234



























                      draft saved

                      draft discarded
















































                      Thanks for contributing an answer to Super User!


                      • Please be sure to answer the question. Provide details and share your research!

                      But avoid


                      • Asking for help, clarification, or responding to other answers.

                      • Making statements based on opinion; back them up with references or personal experience.

                      To learn more, see our tips on writing great answers.




                      draft saved


                      draft discarded














                      StackExchange.ready(
                      function ()
                      StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fsuperuser.com%2fquestions%2f1421123%2fwatching-something-be-piped-to-a-file-live-with-tail%23new-answer', 'question_page');

                      );

                      Post as a guest















                      Required, but never shown





















































                      Required, but never shown














                      Required, but never shown












                      Required, but never shown







                      Required, but never shown

































                      Required, but never shown














                      Required, but never shown












                      Required, but never shown







                      Required, but never shown







                      Popular posts from this blog

                      名間水力發電廠 目录 沿革 設施 鄰近設施 註釋 外部連結 导航菜单23°50′10″N 120°42′41″E / 23.83611°N 120.71139°E / 23.83611; 120.7113923°50′10″N 120°42′41″E / 23.83611°N 120.71139°E / 23.83611; 120.71139計畫概要原始内容臺灣第一座BOT 模式開發的水力發電廠-名間水力電廠名間水力發電廠 水利署首件BOT案原始内容《小檔案》名間電廠 首座BOT水力發電廠原始内容名間電廠BOT - 經濟部水利署中區水資源局

                      Prove that NP is closed under karp reduction?Space(n) not closed under Karp reductions - what about NTime(n)?Class P is closed under rotation?Prove or disprove that $NL$ is closed under polynomial many-one reductions$mathbfNC_2$ is closed under log-space reductionOn Karp reductionwhen can I know if a class (complexity) is closed under reduction (cook/karp)Check if class $PSPACE$ is closed under polyonomially space reductionIs NPSPACE also closed under polynomial-time reduction and under log-space reduction?Prove PSPACE is closed under complement?Prove PSPACE is closed under union?

                      Is my guitar’s action too high? Announcing the arrival of Valued Associate #679: Cesar Manara Planned maintenance scheduled April 23, 2019 at 23:30 UTC (7:30pm US/Eastern)Strings too stiff on a recently purchased acoustic guitar | Cort AD880CEIs the action of my guitar really high?Μy little finger is too weak to play guitarWith guitar, how long should I give my fingers to strengthen / callous?When playing a fret the guitar sounds mutedPlaying (Barre) chords up the guitar neckI think my guitar strings are wound too tight and I can't play barre chordsF barre chord on an SG guitarHow to find to the right strings of a barre chord by feel?High action on higher fret on my steel acoustic guitar