mirror of
https://github.com/python-kasa/python-kasa.git
synced 2025-01-24 05:37:59 +00:00
91 lines
2.2 KiB
Markdown
91 lines
2.2 KiB
Markdown
# pyHS100
|
|
|
|
Python Library to control TPLink smart plugs (HS100, HS105, HS110, HS200) and TPLink smart bulbs (LB1xx).
|
|
|
|
# Usage
|
|
|
|
The package is shipped with a console tool named pyhs100, please refer to ```pyhs100 --help``` for detailed usage.
|
|
<b>Note: The tool does not currently support bulb-specific commands, please feel free to prepare a pull request!</b>
|
|
|
|
## Discovering devices
|
|
|
|
```
|
|
$ pyhs100 discover
|
|
|
|
Discovering devices for 5 seconds
|
|
Found device: {'ip': '192.168.250.186',
|
|
'port': 9999,
|
|
'sys_info': {'emeter': {'get_realtime': {'current': 0.013309,
|
|
<snip>
|
|
```
|
|
|
|
## Querying the state
|
|
```
|
|
$ pyhs100 --ip 192.168.250.186
|
|
|
|
== My Smart Plug - HS110(EU) ==
|
|
Device state: OFF
|
|
LED state: False
|
|
Time: 1970-01-01 01:52:35
|
|
On since: 2017-03-19 17:09:16.408657
|
|
Hardware: 1.0
|
|
Software: 1.0.8 Build 151101 Rel.24452
|
|
MAC (rssi): 50:C7:BF:XX:XX:XX (-61)
|
|
Location: {'longitude': XXXX, 'latitude': XXXX}
|
|
== Emeter ==
|
|
Current state: {'power': 0, 'total': 0.001, 'current': 0.013552, 'voltage': 223.394238}
|
|
```
|
|
|
|
# Library usage
|
|
|
|
For all available API functions run ```help(SmartPlug)``` or ```help(SmartBulb)```.
|
|
|
|
```python
|
|
from pyHS100 import SmartPlug, SmartBulb
|
|
from pprint import pformat as pf
|
|
|
|
plug = SmartPlug("192.168.250.186")
|
|
print("Alias, type and supported features: %s" % (plug.identify(),))
|
|
print("Hardware: %s" % pf(plug.hw_info))
|
|
print("Full sysinfo: %s" % pf(plug.get_sysinfo())) # this prints lots of information about the device
|
|
```
|
|
|
|
## Time information
|
|
```python
|
|
print("Current time: %s" % plug.time)
|
|
print("Timezone: %s" % plug.timezone)
|
|
```
|
|
|
|
## Getting and setting the name
|
|
```python
|
|
print("Alias: %s" % plug.alias)
|
|
plug.alias = "My New Smartplug"
|
|
```
|
|
|
|
## State & switching
|
|
```python
|
|
print("Current state: %s" % plug.state)
|
|
plug.turn_off()
|
|
plug.turn_on()
|
|
```
|
|
or
|
|
```python
|
|
plug.state = "ON"
|
|
plug.state = "OFF"
|
|
```
|
|
|
|
## Getting emeter status (on HS110)
|
|
```python
|
|
print("Current consumption: %s" % plug.get_emeter_realtime())
|
|
print("Per day: %s" % plug.get_emeter_daily(year=2016, month=12))
|
|
print("Per month: %s" % plug.get_emeter_monthly(year=2016))
|
|
```
|
|
|
|
## Switching the led
|
|
```python
|
|
print("Current LED state: %s" % plug.led)
|
|
plug.led = False # turn off led
|
|
print("New LED state: %s" % plug.led)
|
|
|
|
```
|