summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorCoprDistGit <infra@openeuler.org>2023-04-10 10:44:23 +0000
committerCoprDistGit <infra@openeuler.org>2023-04-10 10:44:23 +0000
commit502a56fff9326c49e6fb35ddffd5f51d19324c62 (patch)
treec77baa0a49b22e44e9c0ca4f01c1b5df67f69b15
parentd9c4e77b2d7e27a7d703fe235511ac52437cb2f8 (diff)
automatic import of python-pyppeteer
-rw-r--r--.gitignore1
-rw-r--r--python-pyppeteer.spec349
-rw-r--r--sources1
3 files changed, 351 insertions, 0 deletions
diff --git a/.gitignore b/.gitignore
index e69de29..9f447f5 100644
--- a/.gitignore
+++ b/.gitignore
@@ -0,0 +1 @@
+/pyppeteer-1.0.2.tar.gz
diff --git a/python-pyppeteer.spec b/python-pyppeteer.spec
new file mode 100644
index 0000000..444e009
--- /dev/null
+++ b/python-pyppeteer.spec
@@ -0,0 +1,349 @@
+%global _empty_manifest_terminate_build 0
+Name: python-pyppeteer
+Version: 1.0.2
+Release: 1
+Summary: Headless chrome/chromium automation library (unofficial port of puppeteer)
+License: MIT
+URL: https://github.com/pyppeteer/pyppeteer
+Source0: https://mirrors.nju.edu.cn/pypi/web/packages/68/d6/10e7dfaa677888f59bb68902729e0b3d4dee540642533f60a4cdb8c1eb63/pyppeteer-1.0.2.tar.gz
+BuildArch: noarch
+
+Requires: python3-appdirs
+Requires: python3-importlib-metadata
+Requires: python3-pyee
+Requires: python3-tqdm
+Requires: python3-urllib3
+Requires: python3-websockets
+Requires: python3-certifi
+
+%description
+[![PyPI](https://img.shields.io/pypi/v/pyppeteer.svg)](https://pypi.python.org/pypi/pyppeteer)
+[![PyPI version](https://img.shields.io/pypi/pyversions/pyppeteer.svg)](https://pypi.python.org/pypi/pyppeteer)
+[![Documentation](https://img.shields.io/badge/docs-latest-brightgreen.svg)](https://pyppeteer.github.io/pyppeteer/)
+[![CircleCI](https://circleci.com/gh/pyppeteer/pyppeteer.svg?style=shield)](https://circleci.com/gh/pyppeteer/pyppeteer)
+[![codecov](https://codecov.io/gh/pyppeteer/pyppeteer/branch/dev/graph/badge.svg)](https://codecov.io/gh/pyppeteer/pyppeteer)
+_Note: this is a continuation of the [pyppeteer project](https://github.com/miyakogi/pyppeteer)_. Before undertaking any sort of developement, it is highly recommended that you take a look at [#16](https://github.com/pyppeteer/pyppeteer/pull/16) for the ongoing effort to update this library to avoid duplicating efforts.
+Unofficial Python port of [puppeteer](https://github.com/GoogleChrome/puppeteer) JavaScript (headless) chrome/chromium browser automation library.
+* Free software: MIT license (including the work distributed under the Apache 2.0 license)
+* Documentation: https://pyppeteer.github.io/pyppeteer/
+## Installation
+pyppeteer requires Python >= 3.6
+Install with `pip` from PyPI:
+```
+pip install pyppeteer
+```
+Or install the latest version from [this github repo](https://github.com/pyppeteer/pyppeteer/):
+```
+pip install -U git+https://github.com/pyppeteer/pyppeteer@dev
+```
+## Usage
+> **Note**: When you run pyppeteer for the first time, it downloads the latest version of Chromium (~150MB) if it is not found on your system. If you don't prefer this behavior, ensure that a suitable Chrome binary is installed. One way to do this is to run `pyppeteer-install` command before prior to using this library.
+Full documentation can be found [here](https://pyppeteer.github.io/pyppeteer/reference.html). [Puppeteer's documentation](https://github.com/GoogleChrome/puppeteer/blob/master/docs/api.md#) and [its troubleshooting guide](https://github.com/GoogleChrome/puppeteer/blob/master/docs/troubleshooting.md) are also great resources for pyppeteer users.
+### Examples
+Open web page and take a screenshot:
+```py
+import asyncio
+from pyppeteer import launch
+async def main():
+ browser = await launch()
+ page = await browser.newPage()
+ await page.goto('https://example.com')
+ await page.screenshot({'path': 'example.png'})
+ await browser.close()
+asyncio.get_event_loop().run_until_complete(main())
+```
+Evaluate javascript on a page:
+```py
+import asyncio
+from pyppeteer import launch
+async def main():
+ browser = await launch()
+ page = await browser.newPage()
+ await page.goto('https://example.com')
+ await page.screenshot({'path': 'example.png'})
+ dimensions = await page.evaluate('''() => {
+ return {
+ width: document.documentElement.clientWidth,
+ height: document.documentElement.clientHeight,
+ deviceScaleFactor: window.devicePixelRatio,
+ }
+ }''')
+ print(dimensions)
+ # >>> {'width': 800, 'height': 600, 'deviceScaleFactor': 1}
+ await browser.close()
+asyncio.get_event_loop().run_until_complete(main())
+```
+## Differences between puppeteer and pyppeteer
+pyppeteer strives to replicate the puppeteer API as close as possible, however, fundamental differences between Javascript and Python make this difficult to do precisely. More information on specifics can be found in the [documentation](https://pyppeteer.github.io/pyppeteer/reference.html).
+### Keyword arguments for options
+puppeteer uses an object for passing options to functions/methods. pyppeteer methods/functions accept both dictionary (python equivalent to JavaScript's objects) and keyword arguments for options.
+Dictionary style options (similar to puppeteer):
+```python
+browser = await launch({'headless': True})
+```
+Keyword argument style options (more pythonic, isn't it?):
+```python
+browser = await launch(headless=True)
+```
+### Element selector method names
+In python, `$` is not a valid identifier. The equivalent methods to Puppeteer's `$`, `$$`, and `$x` methods are listed below, along with some shorthand methods for your convenience:
+| puppeteer | pyppeteer | pyppeteer shorthand |
+|-----------|-------------------------|----------------------|
+| Page.$() | Page.querySelector() | Page.J() |
+| Page.$$() | Page.querySelectorAll() | Page.JJ() |
+| Page.$x() | Page.xpath() | Page.Jx() |
+### Arguments of `Page.evaluate()` and `Page.querySelectorEval()`
+puppeteer's version of `evaluate()` takes a JavaScript function or a string representation of a JavaScript expression. pyppeteer takes string representation of JavaScript expression or function. pyppeteer will try to automatically detect if the string is function or expression, but it will fail sometimes. If an expression is erroneously treated as function and an error is raised, try setting `force_expr` to `True`, to force pyppeteer to treat the string as expression.
+### Examples:
+Get a page's `textContent`:
+```python
+content = await page.evaluate('document.body.textContent', force_expr=True)
+```
+Get an element's `textContent`:
+```python
+element = await page.querySelector('h1')
+title = await page.evaluate('(element) => element.textContent', element)
+```
+## Roadmap
+See [projects](https://github.com/pyppeteer/pyppeteer/projects)
+## Credits
+###### This package was created with [Cookiecutter](https://github.com/audreyr/cookiecutter) and the [audreyr/cookiecutter-pypackage](https://github.com/audreyr/cookiecutter-pypackage) project template.
+
+%package -n python3-pyppeteer
+Summary: Headless chrome/chromium automation library (unofficial port of puppeteer)
+Provides: python-pyppeteer
+BuildRequires: python3-devel
+BuildRequires: python3-setuptools
+BuildRequires: python3-pip
+%description -n python3-pyppeteer
+[![PyPI](https://img.shields.io/pypi/v/pyppeteer.svg)](https://pypi.python.org/pypi/pyppeteer)
+[![PyPI version](https://img.shields.io/pypi/pyversions/pyppeteer.svg)](https://pypi.python.org/pypi/pyppeteer)
+[![Documentation](https://img.shields.io/badge/docs-latest-brightgreen.svg)](https://pyppeteer.github.io/pyppeteer/)
+[![CircleCI](https://circleci.com/gh/pyppeteer/pyppeteer.svg?style=shield)](https://circleci.com/gh/pyppeteer/pyppeteer)
+[![codecov](https://codecov.io/gh/pyppeteer/pyppeteer/branch/dev/graph/badge.svg)](https://codecov.io/gh/pyppeteer/pyppeteer)
+_Note: this is a continuation of the [pyppeteer project](https://github.com/miyakogi/pyppeteer)_. Before undertaking any sort of developement, it is highly recommended that you take a look at [#16](https://github.com/pyppeteer/pyppeteer/pull/16) for the ongoing effort to update this library to avoid duplicating efforts.
+Unofficial Python port of [puppeteer](https://github.com/GoogleChrome/puppeteer) JavaScript (headless) chrome/chromium browser automation library.
+* Free software: MIT license (including the work distributed under the Apache 2.0 license)
+* Documentation: https://pyppeteer.github.io/pyppeteer/
+## Installation
+pyppeteer requires Python >= 3.6
+Install with `pip` from PyPI:
+```
+pip install pyppeteer
+```
+Or install the latest version from [this github repo](https://github.com/pyppeteer/pyppeteer/):
+```
+pip install -U git+https://github.com/pyppeteer/pyppeteer@dev
+```
+## Usage
+> **Note**: When you run pyppeteer for the first time, it downloads the latest version of Chromium (~150MB) if it is not found on your system. If you don't prefer this behavior, ensure that a suitable Chrome binary is installed. One way to do this is to run `pyppeteer-install` command before prior to using this library.
+Full documentation can be found [here](https://pyppeteer.github.io/pyppeteer/reference.html). [Puppeteer's documentation](https://github.com/GoogleChrome/puppeteer/blob/master/docs/api.md#) and [its troubleshooting guide](https://github.com/GoogleChrome/puppeteer/blob/master/docs/troubleshooting.md) are also great resources for pyppeteer users.
+### Examples
+Open web page and take a screenshot:
+```py
+import asyncio
+from pyppeteer import launch
+async def main():
+ browser = await launch()
+ page = await browser.newPage()
+ await page.goto('https://example.com')
+ await page.screenshot({'path': 'example.png'})
+ await browser.close()
+asyncio.get_event_loop().run_until_complete(main())
+```
+Evaluate javascript on a page:
+```py
+import asyncio
+from pyppeteer import launch
+async def main():
+ browser = await launch()
+ page = await browser.newPage()
+ await page.goto('https://example.com')
+ await page.screenshot({'path': 'example.png'})
+ dimensions = await page.evaluate('''() => {
+ return {
+ width: document.documentElement.clientWidth,
+ height: document.documentElement.clientHeight,
+ deviceScaleFactor: window.devicePixelRatio,
+ }
+ }''')
+ print(dimensions)
+ # >>> {'width': 800, 'height': 600, 'deviceScaleFactor': 1}
+ await browser.close()
+asyncio.get_event_loop().run_until_complete(main())
+```
+## Differences between puppeteer and pyppeteer
+pyppeteer strives to replicate the puppeteer API as close as possible, however, fundamental differences between Javascript and Python make this difficult to do precisely. More information on specifics can be found in the [documentation](https://pyppeteer.github.io/pyppeteer/reference.html).
+### Keyword arguments for options
+puppeteer uses an object for passing options to functions/methods. pyppeteer methods/functions accept both dictionary (python equivalent to JavaScript's objects) and keyword arguments for options.
+Dictionary style options (similar to puppeteer):
+```python
+browser = await launch({'headless': True})
+```
+Keyword argument style options (more pythonic, isn't it?):
+```python
+browser = await launch(headless=True)
+```
+### Element selector method names
+In python, `$` is not a valid identifier. The equivalent methods to Puppeteer's `$`, `$$`, and `$x` methods are listed below, along with some shorthand methods for your convenience:
+| puppeteer | pyppeteer | pyppeteer shorthand |
+|-----------|-------------------------|----------------------|
+| Page.$() | Page.querySelector() | Page.J() |
+| Page.$$() | Page.querySelectorAll() | Page.JJ() |
+| Page.$x() | Page.xpath() | Page.Jx() |
+### Arguments of `Page.evaluate()` and `Page.querySelectorEval()`
+puppeteer's version of `evaluate()` takes a JavaScript function or a string representation of a JavaScript expression. pyppeteer takes string representation of JavaScript expression or function. pyppeteer will try to automatically detect if the string is function or expression, but it will fail sometimes. If an expression is erroneously treated as function and an error is raised, try setting `force_expr` to `True`, to force pyppeteer to treat the string as expression.
+### Examples:
+Get a page's `textContent`:
+```python
+content = await page.evaluate('document.body.textContent', force_expr=True)
+```
+Get an element's `textContent`:
+```python
+element = await page.querySelector('h1')
+title = await page.evaluate('(element) => element.textContent', element)
+```
+## Roadmap
+See [projects](https://github.com/pyppeteer/pyppeteer/projects)
+## Credits
+###### This package was created with [Cookiecutter](https://github.com/audreyr/cookiecutter) and the [audreyr/cookiecutter-pypackage](https://github.com/audreyr/cookiecutter-pypackage) project template.
+
+%package help
+Summary: Development documents and examples for pyppeteer
+Provides: python3-pyppeteer-doc
+%description help
+[![PyPI](https://img.shields.io/pypi/v/pyppeteer.svg)](https://pypi.python.org/pypi/pyppeteer)
+[![PyPI version](https://img.shields.io/pypi/pyversions/pyppeteer.svg)](https://pypi.python.org/pypi/pyppeteer)
+[![Documentation](https://img.shields.io/badge/docs-latest-brightgreen.svg)](https://pyppeteer.github.io/pyppeteer/)
+[![CircleCI](https://circleci.com/gh/pyppeteer/pyppeteer.svg?style=shield)](https://circleci.com/gh/pyppeteer/pyppeteer)
+[![codecov](https://codecov.io/gh/pyppeteer/pyppeteer/branch/dev/graph/badge.svg)](https://codecov.io/gh/pyppeteer/pyppeteer)
+_Note: this is a continuation of the [pyppeteer project](https://github.com/miyakogi/pyppeteer)_. Before undertaking any sort of developement, it is highly recommended that you take a look at [#16](https://github.com/pyppeteer/pyppeteer/pull/16) for the ongoing effort to update this library to avoid duplicating efforts.
+Unofficial Python port of [puppeteer](https://github.com/GoogleChrome/puppeteer) JavaScript (headless) chrome/chromium browser automation library.
+* Free software: MIT license (including the work distributed under the Apache 2.0 license)
+* Documentation: https://pyppeteer.github.io/pyppeteer/
+## Installation
+pyppeteer requires Python >= 3.6
+Install with `pip` from PyPI:
+```
+pip install pyppeteer
+```
+Or install the latest version from [this github repo](https://github.com/pyppeteer/pyppeteer/):
+```
+pip install -U git+https://github.com/pyppeteer/pyppeteer@dev
+```
+## Usage
+> **Note**: When you run pyppeteer for the first time, it downloads the latest version of Chromium (~150MB) if it is not found on your system. If you don't prefer this behavior, ensure that a suitable Chrome binary is installed. One way to do this is to run `pyppeteer-install` command before prior to using this library.
+Full documentation can be found [here](https://pyppeteer.github.io/pyppeteer/reference.html). [Puppeteer's documentation](https://github.com/GoogleChrome/puppeteer/blob/master/docs/api.md#) and [its troubleshooting guide](https://github.com/GoogleChrome/puppeteer/blob/master/docs/troubleshooting.md) are also great resources for pyppeteer users.
+### Examples
+Open web page and take a screenshot:
+```py
+import asyncio
+from pyppeteer import launch
+async def main():
+ browser = await launch()
+ page = await browser.newPage()
+ await page.goto('https://example.com')
+ await page.screenshot({'path': 'example.png'})
+ await browser.close()
+asyncio.get_event_loop().run_until_complete(main())
+```
+Evaluate javascript on a page:
+```py
+import asyncio
+from pyppeteer import launch
+async def main():
+ browser = await launch()
+ page = await browser.newPage()
+ await page.goto('https://example.com')
+ await page.screenshot({'path': 'example.png'})
+ dimensions = await page.evaluate('''() => {
+ return {
+ width: document.documentElement.clientWidth,
+ height: document.documentElement.clientHeight,
+ deviceScaleFactor: window.devicePixelRatio,
+ }
+ }''')
+ print(dimensions)
+ # >>> {'width': 800, 'height': 600, 'deviceScaleFactor': 1}
+ await browser.close()
+asyncio.get_event_loop().run_until_complete(main())
+```
+## Differences between puppeteer and pyppeteer
+pyppeteer strives to replicate the puppeteer API as close as possible, however, fundamental differences between Javascript and Python make this difficult to do precisely. More information on specifics can be found in the [documentation](https://pyppeteer.github.io/pyppeteer/reference.html).
+### Keyword arguments for options
+puppeteer uses an object for passing options to functions/methods. pyppeteer methods/functions accept both dictionary (python equivalent to JavaScript's objects) and keyword arguments for options.
+Dictionary style options (similar to puppeteer):
+```python
+browser = await launch({'headless': True})
+```
+Keyword argument style options (more pythonic, isn't it?):
+```python
+browser = await launch(headless=True)
+```
+### Element selector method names
+In python, `$` is not a valid identifier. The equivalent methods to Puppeteer's `$`, `$$`, and `$x` methods are listed below, along with some shorthand methods for your convenience:
+| puppeteer | pyppeteer | pyppeteer shorthand |
+|-----------|-------------------------|----------------------|
+| Page.$() | Page.querySelector() | Page.J() |
+| Page.$$() | Page.querySelectorAll() | Page.JJ() |
+| Page.$x() | Page.xpath() | Page.Jx() |
+### Arguments of `Page.evaluate()` and `Page.querySelectorEval()`
+puppeteer's version of `evaluate()` takes a JavaScript function or a string representation of a JavaScript expression. pyppeteer takes string representation of JavaScript expression or function. pyppeteer will try to automatically detect if the string is function or expression, but it will fail sometimes. If an expression is erroneously treated as function and an error is raised, try setting `force_expr` to `True`, to force pyppeteer to treat the string as expression.
+### Examples:
+Get a page's `textContent`:
+```python
+content = await page.evaluate('document.body.textContent', force_expr=True)
+```
+Get an element's `textContent`:
+```python
+element = await page.querySelector('h1')
+title = await page.evaluate('(element) => element.textContent', element)
+```
+## Roadmap
+See [projects](https://github.com/pyppeteer/pyppeteer/projects)
+## Credits
+###### This package was created with [Cookiecutter](https://github.com/audreyr/cookiecutter) and the [audreyr/cookiecutter-pypackage](https://github.com/audreyr/cookiecutter-pypackage) project template.
+
+%prep
+%autosetup -n pyppeteer-1.0.2
+
+%build
+%py3_build
+
+%install
+%py3_install
+install -d -m755 %{buildroot}/%{_pkgdocdir}
+if [ -d doc ]; then cp -arf doc %{buildroot}/%{_pkgdocdir}; fi
+if [ -d docs ]; then cp -arf docs %{buildroot}/%{_pkgdocdir}; fi
+if [ -d example ]; then cp -arf example %{buildroot}/%{_pkgdocdir}; fi
+if [ -d examples ]; then cp -arf examples %{buildroot}/%{_pkgdocdir}; fi
+pushd %{buildroot}
+if [ -d usr/lib ]; then
+ find usr/lib -type f -printf "/%h/%f\n" >> filelist.lst
+fi
+if [ -d usr/lib64 ]; then
+ find usr/lib64 -type f -printf "/%h/%f\n" >> filelist.lst
+fi
+if [ -d usr/bin ]; then
+ find usr/bin -type f -printf "/%h/%f\n" >> filelist.lst
+fi
+if [ -d usr/sbin ]; then
+ find usr/sbin -type f -printf "/%h/%f\n" >> filelist.lst
+fi
+touch doclist.lst
+if [ -d usr/share/man ]; then
+ find usr/share/man -type f -printf "/%h/%f.gz\n" >> doclist.lst
+fi
+popd
+mv %{buildroot}/filelist.lst .
+mv %{buildroot}/doclist.lst .
+
+%files -n python3-pyppeteer -f filelist.lst
+%dir %{python3_sitelib}/*
+
+%files help -f doclist.lst
+%{_docdir}/*
+
+%changelog
+* Mon Apr 10 2023 Python_Bot <Python_Bot@openeuler.org> - 1.0.2-1
+- Package Spec generated
diff --git a/sources b/sources
new file mode 100644
index 0000000..37c5911
--- /dev/null
+++ b/sources
@@ -0,0 +1 @@
+4c0a0a09a19ae9ed37c1440b574841ce pyppeteer-1.0.2.tar.gz