gpt4 book ai didi

c# - 使用 XPath 查找所有 JavaScript 类型脚本元素

转载 作者:行者123 更新时间:2023-11-30 23:05:28 26 4
gpt4 key购买 nike

我试图找到所有 <script>使用 html-agility-pack(加上 LINQ 和 XPath)在一系列 HTML 文档中添加元素。这些文档在页眉中放置了脚本元素,在页脚中放置了 Google Analytics。首先,我试图定位 header 脚本并将其删除。我的 Notepad++ 显示我有 719 个脚本元素,但我的控制台应用程序只找到其中​​的 55 个。

我需要一些帮助来正确定位它们,这样我才能将它们从文档中删除。

源文件(头部结构),

<!doctype html system "html.dtd">
<html>
<head>
<link rel="stylesheet" href="../IRstyle.css" type="text/css">
<title>Non-hierarchic document clustering</title>
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1">
<meta name="keywords" content="">
<meta name="VW96.objecttype" content="Document">

<script language="JavaScript" type="text/JavaScript">
//Javascript-code goes here
</script>
</head>
<body>
<!--Body contents goes here-->

<!-- in footer -->
<script src="http://www.google-analytics.com/urchin.js" type="text/javascript">
</script>
<script type="text/javascript">
_uacct = "UA-67XXXX-X";
urchinTracker();
</script>
</body>
</html>

到目前为止,我已尝试使用 JavaScript 定位“语言”类型,但在解析 html/head 时只获得了一些成功。我的方法从列表中获取文件名。现在,方法打印出列表中收集的脚本数量,这将更改为“Scripts.Remove();”一旦我得到正确的搜索字符串。

private static void FindTagsToRemove(IEnumerable<string> files)
{
var doc = new HtmlDocument();
List<string> scripts = new List<string>();
List<string> errors = new List<string>();
try
{
foreach (var file in files)
{
doc.Load(@file);
var head = doc.DocumentNode.SelectSingleNode("html/head");
var nodes = new List<HtmlNode>();
bool isScript = false;

foreach (var node in head.ChildNodes.ToList())
{
if (node.NodeType == HtmlNodeType.Element && node.Name.Contains("script"))
{
isScript = !isScript;
scripts.Add(node.OuterHtml);
Console.WriteLine(node.OuterHtml);
}
else if (isScript)
{
nodes.Add(node);
node.Remove();
}
}
}
int nr_scripts = scripts.Count();
Console.WriteLine("Number of scripts in collection: {0}", nr_scripts);
}
catch (Exception Ex)
{
Console.WriteLine(Ex.Message);
}
}

如果有人有更好的方法来定位头节点中的 JavaScript,将不胜感激。任何帮助表示赞赏! :)

最佳答案

如果你只需要<script>元素节点,使用descendant-or-self ( // ) .示例 HTML:

var html =
@"<!doctype html system 'html.dtd'>
<html>
<head>
<link rel='stylesheet' href='../IRstyle.css' type='text/css'>
<title>Non-hierarchic document clustering</title>
<meta http-equiv='Content-Type' content='text/html; charset=iso-8859-1'>
<meta name='keywords' content=''>
<meta name='VW96.objecttype' content='Document'>
<script language='JavaScript' type='text/JavaScript'>
//Javascript-code goes here
</script>
</head>
<body>
<!--Body contents goes here-->

<!-- in footer -->
<script src='http://www.google-analytics.com/urchin.js' type='text/javascript'>
</script>
<script type='text/javascript'>
_uacct = 'UA-67XXXX-X';
urchinTracker();
</script>
</body>
</html>";

解析示例:

var document = new HtmlDocument();
document.LoadHtml(html);
// target only <script> in <head>
// var scriptTags = document.DocumentNode.SelectNodes("//head/script");
var scriptTags = document.DocumentNode.SelectNodes("//script");

foreach (var script in scriptTags) script.Remove();

document.Save(OUTPUT);

输出:

<!doctype html system 'html.dtd'>
<html>
<head>
<link rel='stylesheet' href='../IRstyle.css' type='text/css'>
<title>Non-hierarchic document clustering</title>
<meta http-equiv='Content-Type' content='text/html; charset=iso-8859-1'>
<meta name='keywords' content=''>
<meta name='VW96.objecttype' content='Document'>

</head>
<body>
<!--Body contents goes here-->

<!-- in footer -->


</body>
</html>

关于c# - 使用 XPath 查找所有 JavaScript 类型脚本元素,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48811609/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com