Chilkat HOME Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi DLL Go Java Node.js Objective-C PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(Chilkat2-Python) HTTP Download in Parallel with Simultaneous Range RequestsDemonstrates how to download a large file with parallel simultaneous requests, where each request downloads a segment (range) of the remote file.
import sys import chilkat2 # This requires the Chilkat API to have been previously unlocked. # See Global Unlock Sample for sample code. http = chilkat2.Http() # First get the size of the file to be downloaded. url = "https://www.chilkatsoft.com/hamlet.xml" # resp is a CkHttpResponse resp = http.GetHead(url) if (http.LastMethodSuccess == False): print(http.LastErrorText) sys.exit() remoteFileSize = resp.ContentLength print("Downloading " + str(remoteFileSize) + " bytes...") # Let's download in 4 chunks. # (the last chunk will be whatever remains after the 1st 3 equal sized chunks) chunkSize = remoteFileSize / 4 # The Range header is used to download a range from a resource # Range: bytes=<range-start>-<range-end> # or # Range: bytes=<range-start>- # We're writing code this way for clarity.. http1 = chilkat2.Http() http2 = chilkat2.Http() http3 = chilkat2.Http() http4 = chilkat2.Http() sbRange = chilkat2.StringBuilder() sbRange.SetString("bytes=<range-start>-<range-end>") numReplaced = sbRange.ReplaceI("<range-start>",0) numReplaced = sbRange.ReplaceI("<range-end>",chunkSize - 1) print(sbRange.GetAsString()) http1.SetRequestHeader("Range",sbRange.GetAsString()) sbRange.SetString("bytes=<range-start>-<range-end>") numReplaced = sbRange.ReplaceI("<range-start>",chunkSize) numReplaced = sbRange.ReplaceI("<range-end>",2 * chunkSize - 1) print(sbRange.GetAsString()) http2.SetRequestHeader("Range",sbRange.GetAsString()) sbRange.SetString("bytes=<range-start>-<range-end>") numReplaced = sbRange.ReplaceI("<range-start>",2 * chunkSize) numReplaced = sbRange.ReplaceI("<range-end>",3 * chunkSize - 1) print(sbRange.GetAsString()) http3.SetRequestHeader("Range",sbRange.GetAsString()) sbRange.SetString("bytes=<range-start>-") numReplaced = sbRange.ReplaceI("<range-start>",3 * chunkSize) print(sbRange.GetAsString()) http4.SetRequestHeader("Range",sbRange.GetAsString()) # Start each range download # task1 is a CkTask task1 = http1.DownloadAsync(url,"qa_output/chunk1.dat") task1.Run() # task2 is a CkTask task2 = http2.DownloadAsync(url,"qa_output/chunk2.dat") task2.Run() # task3 is a CkTask task3 = http3.DownloadAsync(url,"qa_output/chunk3.dat") task3.Run() # task4 is a CkTask task4 = http4.DownloadAsync(url,"qa_output/chunk4.dat") task4.Run() # Wait for the downloads to complete. numLive = 4 while numLive > 0 : numLive = 0 if (task1.Live == True): numLive = numLive + 1 if (task2.Live == True): numLive = numLive + 1 if (task3.Live == True): numLive = numLive + 1 if (task4.Live == True): numLive = numLive + 1 if (numLive > 0): # SleepMs is a convenience method to cause the caller to sleep for N millisec. # It does not cause the given task to sleep.. task1.SleepMs(10) # All should be downloaded now.. # Examine the result of each Download. numErrors = 0 if (task1.GetResultBool() == False): print(task1.ResultErrorText) numErrors = numErrors + 1 if (task2.GetResultBool() == False): print(task2.ResultErrorText) numErrors = numErrors + 1 if (task3.GetResultBool() == False): print(task3.ResultErrorText) numErrors = numErrors + 1 if (task4.GetResultBool() == False): print(task4.ResultErrorText) numErrors = numErrors + 1 if (numErrors > 0): sys.exit() # All downloads were successful. # Compose the file from the parts. fac = chilkat2.FileAccess() success = fac.ReassembleFile("qa_output","chunk","dat","qa_output/hamlet.xml") if (success == False): print(fac.LastErrorText) else: print("Success.") # Let's download in the regular way, and then compare files.. success = http.Download(url,"qa_output/hamletRegular.xml") # Compare files. bSame = fac.FileContentsEqual("qa_output/hamlet.xml","qa_output/hamletRegular.xml") print("bSame = " + str(bSame)) |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.