使用 XPath 查找所有 JavaScript 类型的脚本元素
Use XPath to find all JavaScript type script elements
我正在尝试使用 html-agility-pack(加上 LINQ 和 XPath)在一系列 HTML-documents 中找到所有 <script>
元素。
这些文档在 header 中放置了 script-elements,在页脚中放置了 Google 分析。首先,我试图将 header 脚本作为目标并将其删除。我的 Notepad++ 显示我有 719 script-elements 个,但我的控制台应用程序只找到其中的 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 定位 'Language' 类型,但在解析 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);
}
}
如果有人有更好的方法来定位 head-node 中的 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>
我正在尝试使用 html-agility-pack(加上 LINQ 和 XPath)在一系列 HTML-documents 中找到所有 <script>
元素。
这些文档在 header 中放置了 script-elements,在页脚中放置了 Google 分析。首先,我试图将 header 脚本作为目标并将其删除。我的 Notepad++ 显示我有 719 script-elements 个,但我的控制台应用程序只找到其中的 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 定位 'Language' 类型,但在解析 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);
}
}
如果有人有更好的方法来定位 head-node 中的 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>