.txt表内的内容
本文关键字:txt | 更新日期: 2023-09-27 18:33:50
我正在尝试在表中显示文本文件的内容。我已经让它成功读取文本文件,并在div 中显示.txt
文件内容,但是当我尝试在表中显示内容时它会抛出错误。
我做错了什么吗?
这是我的代码隐藏:
protected void btnUpld_Click(object sender, EventArgs e)
{
Stream theStream = file1.PostedFile.InputStream;
//file1 is an asp:FileUpload on .aspx
using (StreamReader viewer = new
StreamReader((Stream)file1.PostedFile.InputStream))
{
while (viewer.Peek() > 0)
{
string txtskip = viewer.ReadLine();
Table1.InnerHtml += txtskip;
//Table1 is the table i'm wanting to put the results in on my .aspx
}
}
}
表
控件没有 Innerhtml
这样的属性。 您需要将文本分配给表格中一行中的列。
你的代码应该是这样的
<asp:Table ID="Table2" runat="server">
<asp:TableRow ID="TableRow1" runat="server">
<asp:TableCell ID="TableCell1" runat="server">
This is Cell 1
</asp:TableCell>
<asp:TableCell ID="TableCell2" runat="server">
This is Cell 2
</asp:TableCell>
</asp:TableRow>
</asp:Table>
现在在服务器端你可以写
TableCell1.Text=somestring;
TableCell2.Text=anotherstring;
这段代码应该可以帮助你
protected void btnRender_Click(object sender, EventArgs e)
{
using (StreamReader viewer = new StreamReader((Stream)file1.PostedFile.InputStream))
{
TableRow tr;
TableCell tc;
while (viewer.Peek() > 0)
{
string txtskip = viewer.ReadLine();
// Table1.InnerHtml += txtskip; //Table1 is the table i'm wanting to put the results in on my .aspx
tr = new TableRow();
tc = new TableCell();
tr.Cells.Add(tc);
Table1.Rows.Add(tr);
tc.Text = txtskip;
}
}
}
谢谢
埃森
你可以做这样的事情。
可以将文本控件放在需要填充数据的td
内。然后
while (viewer.Peek() > 0)
{
string txtskip = viewer.ReadLine();
yourLiteral.text += txtskip;
}
你真的不应该使用文本文件来加载这样的内容。您一定会遇到问题,因为迟早会锁定对该文件的访问。您可以通过将内容加载到Cache
并从那里加载来消除此风险。
按照上面的建议,您将修改下面的示例以从 Cache
中检索文本,但为了清楚起见,并回答您最初的问题,此示例直接从文件中加载它:
using (var reader = new StreamReader("bla.txt"))
{
//use the object initializer to prepare a new literal control
var litCtrl = new Literal
{
Mode = LiteralMode.PassThrough,
Text = string.Format("<table>{0}</table>", reader.ReadToEnd()))
}
//use a literal control to display the table on the page
pnlContainer.Controls.Add(litCtrl);
}