Skip to main content

Grove - Servo

Grove - Servo is DC motor with gearing and feedback system. It is used in driving mechanism of robots. The module is a bonus product for Grove lovers. We regulated the three-wire servo into a Grove standard connector. You can plug and play it as a typical Grove module now, without jumper wires clutter.

But if you feel more like a proto servo, check out EMAX 9g ES08A High Sensitive Mini Servo. They are the same model, both of good quality and burden-free price.


  • Small module
  • Grove Compatible Interface
  • Easy to use


Item Min Typical Max Unit
Working Voltage 4.8 5.0 6.0 V
Torque 1.5/1.8
Speed 0.12/0.16 s/60°
Size 32X11.5X24 mm
Weight 8.5 g

Platforms Supported

ArduinoRaspberry Pi
The platforms mentioned above as supported is/are an indication of the module's software or theoritical compatibility. We only provide software library or code examples for Arduino platform in most cases. It is not possible to provide software library / demo code for all possible MCU platforms. Hence, users have to write their own software library.

Getting Started

Play with Arduino

Here we will show you how this Grove - Servo works via a simple demo. First of all, we need to prepare the below stuffs:

Seeeduino V4Grove - ServoBase Shield
enter image description hereenter image description hereenter image description here
Get ONE NowGet ONE NowGet ONE Now

The Servo has three wires: power, ground, and signal. The power wire is typically red, and should be connected to the 5V pin on the Arduino/Seeeduino board. The ground wire is typically black or brown and should be connected to a ground pin on the Arduino board. The signal pin is typically yellow, orange or white and should be connected to D5 on the Arduino board. We can change to the digital port as we like. But don't forget to change the port number in the definition of the demo code at the same time.

  • Connect the module to D5 port of Base Shield.
  • Plug Grove- Base Shield into Arduino.
  • Connect Arduino to PC via a USB cable.


  • Let's sweep the shaft of a servo back and forth across 180 degrees by using Adruino Servo Library.

  • Open the code directly by the path: File -> Examples ->Servo->Sweep.

/* Sweep
This example code is in the public domain.

modified 8 Nov 2013
by Scott Fitzgerald

#include <Servo.h>

Servo myservo; // create servo object to control a servo
// twelve servo objects can be created on most boards

int pos = 0; // variable to store the servo position

void setup() {
myservo.attach(5); // attaches the servo on pin 5 to the servo object

void loop() {
for (pos = 0; pos <= 180; pos += 1) { // goes from 0 degrees to 180 degrees
// in steps of 1 degree
myservo.write(pos); // tell servo to go to position in variable 'pos'
delay(15); // waits 15ms for the servo to reach the position
for (pos = 180; pos >= 0; pos -= 1) { // goes from 180 degrees to 0 degrees
myservo.write(pos); // tell servo to go to position in variable 'pos'
delay(15); // waits 15ms for the servo to reach the position
  • Upload the sketch. We can see the servo sweep.

Play with Codecraft


Step 1. Connect Grove - Servo to port D5 in a Base Shield.

Step 2. Plug the Base Shield to your Seeeduino/Arduino.

Step 3. Link Seeeduino/Arduino to your PC via an USB cable.


Step 1. Open Codecraft, add Arduino support, and drag a main procedure to working area.

If this is your first time using Codecraft, see also [Guide for Codecraft using Arduino](

Step 2. Drag blocks as picture below or open the cdc file which can be downloaded at the end of this page.


Upload the program to your Arduino/Seeeduino.

When the code finishes uploaded, you will see the servo sweep.

Play With Raspberry Pi (With Grove Base Hat for Raspberry Pi)


  • Step 1. Things used in this project:
Raspberry piGrove Base Hat for RasPiGrove - Servo
enter image description hereenter image description hereenter image description here
Get ONE NowGet ONE NowGet ONE Now
  • Step 2. Plug the Grove Base Hat into Raspberry.
  • Step 3. Connect the Grove - Servo to port 12 of the Base Hat.
  • Step 4. Connect the Raspberry Pi to PC through USB cable.

For step 3 you are able to connect the servo module to **any GPIO Port** but make sure you change the command with the corresponding port number.


 If you are using **Raspberry Pi with Raspberrypi OS >= Bullseye**, you have to use this command line **only with Python3**.
  • Step 1. Follow Setting Software to configure the development environment.
  • Step 2. Download the source file by cloning the library.
cd ~
git clone

  • Step 3. Excute below commands to run the code.
python3 12

Following is the code.

import RPi.GPIO as IO
import sys
import time
from numpy import interp


class GroveServo:

def __init__(self, channel):
self.pwm = IO.PWM(channel,50)

def __del__(self):

def setAngle(self, angle):
# Map angle from range 0 ~ 180 to range 25 ~ 125
angle = max(min(angle, GroveServo.MAX_DEGREE), GroveServo.MIN_DEGREE)
tmp = interp(angle, [0, 180], [25, 125])
self.pwm.ChangeDutyCycle(round(tmp/10.0, 1))

Grove = GroveServo

def main():
if len(sys.argv) < 2:
print('Usage: {} servo_channel'.format(sys.argv[0]))

servo = GroveServo(int(sys.argv[1]))

while True:
for x in range(0, 180):
print x, "degree"
for x in range(180, 0, -1):
print x, "degree"

if __name__ == '__main__':

If everything goes well, you will be able to see the servo sweep.

pi@raspberrypi:~/ $ python3 12
0 degree
1 degree
2 degree
3 degree
4 degree
5 degree
6 degree
7 degree
8 degree
9 degree
10 degree
11 degree
12 degree
13 degree
14 degree
15 degree
16 degree
17 degree
18 degree
19 degree
20 degree
21 degree
^CTraceback (most recent call last):
File "", line 81, in <module>
File "", line 74, in main

You can quit this program by simply press ++ctrl+c++.



Servomotor Grove module:

Tech Support & Product Discussion

Thank you for choosing our products! We are here to provide you with different support to ensure that your experience with our products is as smooth as possible. We offer several communication channels to cater to different preferences and needs.

Loading Comments...