日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

Behave用户自定义数据类型

發布時間:2023/12/13 编程问答 25 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Behave用户自定义数据类型 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

在step句子中, 所有的參數默認是string類型, 如果用戶想使用復雜的或者其他數據類型, 就需要了解以下bahave中的數據類型.

behave的數據類型轉換器是在parse和cfparse中支持.

parse模塊是string.format的逆函數.? parse_type是基于parse的擴展, 簡化了自定義數據類型的產生.

parse feature

    • 在類型轉換器中可選pattern
    • 函數描述符with_pattern()

parse_type feature

    • 簡化類型轉換器的生成
    • 基于cardinality創建類型轉換器
    • 提供擴展的解析器支持cardinality field
      CardinalityExampleDescription
      0..1“{person:Person?}”Zero or one: For optional parts.
      0..*“{persons:Person*}”Zero or more: For list<T> (many0).
      1..*“{persons:Person+}”One or more: For list<T> (many).

如何定義自定義數據類型

  • 用戶注冊一個數據類型, 例如在environment.py文件中
  • parse.Parse匹配string作為一個數據類型, 然后它調用類型轉換器去轉換匹配的文本為目標數據類型
    #普通的類型轉換 from behave import register_typedef parse_number(text):"""Convert parsed text into a number.:param text: Parsed text, called by :py:meth:`parse.Parser.parse()`.:return: Number instance (integer), created from parsed text."""return int(text) # -- REGISTER: User-defined type converter (parse_type). register_type(Number=parse_number)#帶有正則的類型轉換 @parse.with_pattern(r"a\s+") def parse_word_a(text):"""Type converter for "a " (followed by one/more spaces)."""return text.strip()register_type(a_=parse_word_a)
  • parse中預定義的數據類型

    http://jenisys.github.io/behave.example/datatype/builtin_types.html

    Cardinality 0 or 1(optional)

    #這個實現比上一個實現多了一步 TypeBuilder.with_optional(parse_word_a). from behave import register_type from parse_type import TypeBuilder import parse@parse.with_pattern(r"a\s+") def parse_word_a(text):"""Type converter for "a " (followed by one/more spaces)."""return text.strip()# -- SAME: # parse_optional_word_a = TypeBuilder.with_zero_or_one(parse_word_a) parse_optional_word_a = TypeBuilder.with_optional(parse_word_a) register_type(optional_a_=parse_optional_word_a)#step_impl中{:optional_a_}是一個可選項, 在step既可以有"a "也可以沒有 @when('attacked by {:optional_a_}{opponent}') def step_attacked_by(context, a_, opponent):context.ninja_fight.opponent = opponent

    ?

    Cardinality 1++

    from behave import register_type from parse_type import TypeBuildercompany_persons = [ "Alice", "Bob", "Charly", "Dodo" ] parse_person = TypeBuilder.make_choice(company_persons) register_type(Person=parse_person)# -- MANY-TYPE: Persons := list<Person> with list-separator = "and" # parse_persons = TypeBuilder.with_one_or_more(parse_person, listsep="and") parse_persons = TypeBuilder.with_many(parse_person, listsep="and") register_type(PersonAndMore=parse_persons)# -- NEEDED-UNTIL: parse_type.cfparse.Parser is used by behave. # parse_persons2 = TypeBuilder.with_many(parse_person) # type_dict = {"Person+": parse_persons2} # register_type(**type_dict)

    ?

      Cardinality 0++

    from behave import register_type from parse_type import TypeBuilderdef slurp_space(text):return text slurp_space.pattern = r"\s*" register_type(slurp_space=slurp_space)parse_color = TypeBuilder.make_choice([ "red", "green", "blue", "yellow" ]) register_type(Color=parse_color)# -- MANY-TYPE: Persons := list<Person> with list-separator = "and" # parse_colors = TypeBuilder.with_many0(parse_color, listsep="and") parse_colors0A= TypeBuilder.with_zero_or_more(parse_color, listsep="and") register_type(OptionalColorAndMore=parse_colors0A)

    ?

      

    ?

    ?

    轉載于:https://www.cnblogs.com/v394435982/p/6403179.html

    總結

    以上是生活随笔為你收集整理的Behave用户自定义数据类型的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。