如何根据 class 标签和 Dart/Flutter 中的属性名称抓取数据

How to scrape data based on class tag and attribute name in Dart/Flutter

我试图在这个 html 中找到另一种抓取数据的方法。我试图获得的值是 'e4s1' 值 .

<section class="row btn-row">
        <input type="hidden" name="execution" value="e4s1"/>

基本上我已经找到了一种使用以下代码获取此值的方法。但这取决于 html 代码中的标记位置。在这种情况下,在 'input'[2].

import 'package:http/http.dart' as http;
import 'package:html/parser.dart';
import 'package:html/dom.dart' as dom;

.....
Future getLoginAuth() async {
    var response = await http.get(Uri.parse(url), headers: header);

    if (response.statusCode == 200) {
      dom.Document document = parse(response.body);
      final elements =
          document.getElementsByTagName('input')[2].attributes['value'];
      print(elements);
    }
......

那么,有没有办法使用标签和名称属性找到值 'e4s1'? 例如,使用 tag:input 和属性:姓名='execution'。我正在尝试在 Dart 中找到一种方法来执行此操作,例如在 python 中使用 BeautifulSoup 包,如下面的代码所示:

soup.find('input', attrs={'name':'execution'})['value']

您可以使用 xml 包解析 HTML。像这样:

final html = 
'''<section class="row btn-row">
        <input type="hidden" name="execution" value="e4s1"/>
</section>''';

final document = XmlDocument.parse(html);
final inputs = document.findAllElements('input');

inputs.forEach((node) => print(node.attributes));

attributes是当前节点所有属性的列表。

归功于 @user2233706,这让我使用了 forEach()。所以,这就是我使用 HTML 包的方式:

import 'package:http/http.dart' as http;
import 'package:html/parser.dart';
import 'package:html/dom.dart' as dom;


Future getLoginAuth() async {
    var response = await http.get(Uri.parse(url), headers: header);

    if (response.statusCode == 200) {
      dom.Document document = parse(response.body);
      List data = document.getElementsByTagName('input');

      data.forEach(
        (element) {
          if (element.attributes.containsValue('execution') == true) {
            print(element.attributes['value']);
          }
        },
      );   
      }