Skip to main content

Why is Pyodide giving me a 'File is not a zip file' error when I try to install a .whl package using micropip?

I'm trying to import a .whl package using micropip into pyodide for use in an html file, but am getting an error about "must be a zip file"?

Based on the documentation of micropip here, I assume the micropip.install() should be linked to a .whl file and not .zip. I used python3 -m build to create the .whl file, and then uploaded it to github.

This is the error code:

pyodide.asm.js:14 Uncaught (in promise) PythonError: Traceback (most recent call last):   File "/lib/python3.10/asyncio/futures.py", line 201, in result     raise self._exception   File "/lib/python3.10/asyncio/tasks.py", line 234, in __step     result = coro.throw(exc)   File "/lib/python3.10/site-packages/micropip/_micropip.py", line 183, in install     transaction = await self.gather_requirements(requirements, ctx, keep_going)   File "/lib/python3.10/site-packages/micropip/_micropip.py", line 173, in gather_requirements     await gather(*requirement_promises)   File "/lib/python3.10/asyncio/futures.py", line 284, in __await__     yield self  # This tells Task to wait for completion.   File "/lib/python3.10/asyncio/tasks.py", line 304, in __wakeup     future.result()   File "/lib/python3.10/asyncio/futures.py", line 201, in result     raise self._exception   File "/lib/python3.10/asyncio/tasks.py", line 232, in __step     result = coro.send(None)   File "/lib/python3.10/site-packages/micropip/_micropip.py", line 245, in add_requirement     await self.add_wheel(name, wheel, version, (), ctx, transaction)   File "/lib/python3.10/site-packages/micropip/_micropip.py", line 313, in add_wheel     with ZipFile(io.BytesIO(wheel_bytes)) as zip_file:   File "/lib/python3.10/zipfile.py", line 1258, in __init__     self._RealGetContents()   File "/lib/python3.10/zipfile.py", line 1325, in _RealGetContents     raise BadZipFile("File is not a zip file") zipfile.BadZipFile: File is not a zip file

My code looks something like this:


<!DOCTYPE html>

    <p>My first Pyodide app</p>
    
    <script type="text/javascript">
      async function main() {
        let pyodide = await loadPyodide();
        await pyodide.loadPackage("micropip");
        const micropip = pyodide.pyimport("micropip");
        await micropip.install("url of .whl file");
        await pyodide.runPython(`
        import <package-name>
      `);
      }
      main();
    </script>


source https://stackoverflow.com/questions/76335688/why-is-pyodide-giving-me-a-file-is-not-a-zip-file-error-when-i-try-to-install

Comments

Popular posts from this blog

ValueError: X has 10 features, but LinearRegression is expecting 1 features as input

So, I am trying to predict the model but its throwing error like it has 10 features but it expacts only 1. So I am confused can anyone help me with it? more importantly its not working for me when my friend runs it. It works perfectly fine dose anyone know the reason about it? cv = KFold(n_splits = 10) all_loss = [] for i in range(9): # 1st for loop over polynomial orders poly_order = i X_train = make_polynomial(x, poly_order) loss_at_order = [] # initiate a set to collect loss for CV for train_index, test_index in cv.split(X_train): print('TRAIN:', train_index, 'TEST:', test_index) X_train_cv, X_test_cv = X_train[train_index], X_test[test_index] t_train_cv, t_test_cv = t[train_index], t[test_index] reg.fit(X_train_cv, t_train_cv) loss_at_order.append(np.mean((t_test_cv - reg.predict(X_test_cv))**2)) # collect loss at fold all_loss.append(np.mean(loss_at_order)) # collect loss at order plt.plot(np.log(al...

Sorting large arrays of big numeric stings

I was solving bigSorting() problem from hackerrank: Consider an array of numeric strings where each string is a positive number with anywhere from to digits. Sort the array's elements in non-decreasing, or ascending order of their integer values and return the sorted array. I know it works as follows: def bigSorting(unsorted): return sorted(unsorted, key=int) But I didnt guess this approach earlier. Initially I tried below: def bigSorting(unsorted): int_unsorted = [int(i) for i in unsorted] int_sorted = sorted(int_unsorted) return [str(i) for i in int_sorted] However, for some of the test cases, it was showing time limit exceeded. Why is it so? PS: I dont know exactly what those test cases were as hacker rank does not reveal all test cases. source https://stackoverflow.com/questions/73007397/sorting-large-arrays-of-big-numeric-stings

How to load Javascript with imported modules?

I am trying to import modules from tensorflowjs, and below is my code. test.html <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title </head> <body> <script src="https://cdn.jsdelivr.net/npm/@tensorflow/tfjs@2.0.0/dist/tf.min.js"></script> <script type="module" src="./test.js"></script> </body> </html> test.js import * as tf from "./node_modules/@tensorflow/tfjs"; import {loadGraphModel} from "./node_modules/@tensorflow/tfjs-converter"; const MODEL_URL = './model.json'; const model = await loadGraphModel(MODEL_URL); const cat = document.getElementById('cat'); model.execute(tf.browser.fromPixels(cat)); Besides, I run the server using python -m http.server in my command prompt(Windows 10), and this is the error prompt in the console log of my browser: Failed to loa...