ROSでパッケージを作成する時に他のサービスが発行するトピックに依存している時など、他のサービスが立ち上がるまで待つ必要がある時があります。

その場合、wait_for_service()関数を使用することで実現できます。この関数は、指定したサービスが提供されるまでPythonスクリプトをブロックし、指定されたタイムアウトが経過すると例外を投げます。

コード例

#!/usr/bin/env python
import rospy
from std_srvs.srv import Empty

rospy.init_node('wait_for_service')

# サービスが提供されるまで待機
rospy.wait_for_service('/my_service')

try:
    # サービスを使用する
    my_service = rospy.ServiceProxy('/my_service', Empty)
    response = my_service()
    rospy.loginfo(response)
except rospy.ServiceException as e:
    rospy.logerr("Service call failed: %s" % e)

この例では、/my_serviceサービスが提供されるまでPythonスクリプトがブロックされます。サービスが提供されると、tryブロック内でmy_service()関数を使用してサービスを呼び出します。もしサービスの呼び出しが失敗した場合は、rospy.logerr()を使用してエラーログを出力します。

Ros

Related Posts

ROSのLaserScanデータの一定角度の範囲を無視する方法
ROSのLaserScanデータの一定角度の範囲を無視する方法
ROSでLidarセンサーを使う時、ロボットの車体など一定角度の範囲に常に障害物があり、これを無視したい時があると思いますが、その方法を紹介します。 以下は、得られた/scan_rawトピックのデータの一定角度の範囲を無視して新しい/...
Read More
ROSのmove_baseで、Pythonからコストマップをクリアする方法
ROSのmove_baseで、Pythonからコストマップをクリアする方法
move_baseを使っていると、障害物が無いのにコストマップで障害物判定されてしまうことがあります。そのようなときは、コストマップを一度クリアしましょう。 コマンドから   move_baseノードには、コストマップをクリアする方法...
Read More
roslaunchでrospy.loginfoでの出力が表示されない場合の対応策
roslaunchでrospy.loginfoでの出力が表示されない場合の対応策
roslaunchで起動したときに、rospy.loginfoで出力しても表示されない場合は下記のように--screenオプションをつけましょう。 コマンドラインで実行する場合 roslaunch your_package your_...
Read More