C# 将字符串值与导入的excel工作表单元格匹配
我敢肯定,我真的很快就能解决这个问题了。我在导入的excel文档中有数千个IP地址。我输入一个IP,我想要它,以便程序将该IP地址与excel工作表中最近的IP地址匹配,然后打印到控制台。我想我的问题是在我的第一个if语句中,我正在解析工作表。任何帮助都将不胜感激。我收到一条未处理的错误消息异常:System.NullReferenceException:对象引用未指向对象的实例。然后,它给出了我的excel工作表的路径,然后是异常,我猜假设它在第一个if语句中C# 将字符串值与导入的excel工作表单元格匹配,c#,excel,ip,match,C#,Excel,Ip,Match,我敢肯定,我真的很快就能解决这个问题了。我在导入的excel文档中有数千个IP地址。我输入一个IP,我想要它,以便程序将该IP地址与excel工作表中最近的IP地址匹配,然后打印到控制台。我想我的问题是在我的第一个if语句中,我正在解析工作表。任何帮助都将不胜感激。我收到一条未处理的错误消息异常:System.NullReferenceException:对象引用未指向对象的实例。然后,它给出了我的excel工作表的路径,然后是异常,我猜假设它在第一个if语句中 using System; us
using System;
using System.Net;
using Microsoft.Office.Interop.Excel;
using Excel = Microsoft.Office.Interop.Excel;
using System.Data.OleDb;
using System.Data;
using System.Runtime.InteropServices;
using System.Text.RegularExpressions;
namespace Investigations
{
class Program
{
static void Main(string[] args)
{
IPAddress addr = IPAddress.Parse("8.8.8.8");
IPHostEntry entry = Dns.GetHostEntry(addr);
Console.WriteLine("IP Address: " + addr);
Console.WriteLine("Host Name: " + entry.HostName);
Excel.Application xlApp = new Excel.Application();
Excel.Workbook xlWorkbook = xlApp.Workbooks.Open(@"C:\subnets.xlsx");
Excel._Worksheet xlWorksheet = xlWorkbook.Sheets[1];
Excel.Range xlRange = xlWorksheet.UsedRange;
bool foundIP = false;
IPAddress excelIP = IPAddress.Parse("8.8.8.8");
for (int i = 0; i < xlWorksheet.Rows.Count; i++)
{
if (IPAddress.TryParse(xlWorksheet.Cells[i + 1, 1].Value.ToString(), out excelIP))
Console.WriteLine(excelIP);
{
// Compare the IP address we found with the one we're looking for
if (excelIP.Equals(addr))
{
foundIP = true;
break;
}
}
}
if (foundIP)
{
Console.WriteLine("Found the IP address!");
Console.WriteLine(excelIP);
}
else
{
Console.WriteLine("Found the IP address!");
}
}
使用系统;
Net系统;
使用Microsoft.Office.Interop.Excel;
使用Excel=Microsoft.Office.Interop.Excel;
使用System.Data.OleDb;
使用系统数据;
使用System.Runtime.InteropServices;
使用System.Text.RegularExpressions;
命名空间调查
{
班级计划
{
静态void Main(字符串[]参数)
{
IPAddress addr=IPAddress.Parse(“8.8.8.8”);
IPHostEntry条目=Dns.GetHostEntry(addr);
控制台写入线(“IP地址:+addr”);
Console.WriteLine(“主机名:”+entry.HostName);
Excel.Application xlApp=新的Excel.Application();
Excel.Workbook xlWorkbook=xlApp.Workbooks.Open(@“C:\subnets.xlsx”);
Excel._工作表xlWorksheet=xlWorkbook.Sheets[1];
Excel.Range xlRange=xlWorksheet.UsedRange;
bool-foundIP=false;
IPAddress excelIP=IPAddress.Parse(“8.8.8.8”);
对于(int i=0;i
这可能是因为您声明了范围对象(使用的行和列)
然后遍历工作表中的行(工作表中使用或未使用的所有行)
试一试
Excel.\u工作表xlWorksheet=xlWorkbook.Sheets[1];
Excel.Range xlRange=xlWorksheet.UsedRange;
对于(int i=0;i
…这可能是因为您声明了范围对象(使用的行和列) 然后遍历工作表中的行(工作表中使用或未使用的所有行) 试一试
Excel.\u工作表xlWorksheet=xlWorkbook.Sheets[1];
Excel.Range xlRange=xlWorksheet.UsedRange;
对于(int i=0;i
…不完全是这样,仍然给我与以前相同的处理异常我想我在你的问题中没有看到你提到抛出异常的地方。也许可以尝试更新它以使其更具体一些?我看到可能缺少的另一件事是遍历列的for。xlsheet。单元格[i+1,1]可能应该在for中(int i=0,i
if
之后只有一行可执行代码,其余的只是一个不相关的代码块。您可能需要移动行Console.WriteLine(excelIP)
在if
块内。否则,之后的代码块将运行,即使excelIP
为空。不完全是这样,仍然给我与以前相同的处理异常。我想我在你的问题中没有看到你提到抛出异常的地方。也许可以尝试更新它以使其更具体?我看到的另一件事是maybe missing是一个for,用于遍历columns.xlWorksheet。单元格[i+1,1]可能位于for(int i=0,iif
之后只有一行可执行代码,其余的只是一个不相关的代码块。您可能需要移动行Console.WriteLine(excelIP)在if
块内。否则,即使excelIP
为空,之后的代码块也会运行。上面的代码正确吗?因为在第一个if
之后只有一行可执行代码,而其余的代码只是一个不相关的代码块,将始终尝试运行。您可能需要移动ineConsole.WriteLine(excelIP);
在if
块内。上面的代码正确吗?因为在第一个if
之后有一行可执行的代码,其余的代码只是一个不相关的代码块,将始终尝试运行。您可能需要移动该行Console.WriteLine(excelIP)在if
块中。
Excel._Worksheet xlWorksheet = xlWorkbook.Sheets[1];
Excel.Range xlRange = xlWorksheet.UsedRange;
for (int i = 0; i < xlRange.Rows.Count; i++)