quarta-feira, 18 de maio de 2022
Como obter a PublicKeyToken de uma biblioteca ou assembly?
Olá pessoal, hoje quero te ajudar a encontrar a PublicKeyToken ou Token de Chave Pública de um aplicativo, assembly ou dll através da linha de comando do power shall.Mas antes disso vamos definir o que é uma PublickKeyToken.
O que é PublicKeyToken?
PublickKeyToken ou token de chave pública é um hash de 64 bits da chave pública que corresponde à chave privada usada para assinar o assembly. Ele é usado para tornar um nome de assembly único.
Por exemplo, temos dois assemblies fortemente nomeados com os mesmos nomes de arquivos, o .NET os tratará como assemblies diferentes porque o token de cada é único.
Vamos a prática
Para obter a PublicKeyToken é muito simples, basta seguir os seguintes passos:
([system.reflection.assembly]::loadfile("C:\projects\demo20\Intelligencia.UrlRewriter.dll")).FullName
Dentro da função loadfile coloca o como parametro o caminho completo da tua dll.
E terás uma resultado parecido com esse:
Intelligencia.UrlRewriter, Version=2.0.0.9, Culture=neutral, PublicKeyToken=0573f3650687980d
Bonús - Como obter a PublicKeyToken via código C#?
Dé uma olhada neste link, se tiveres alguma dúvida podes deixar nos comentários.
https://docs.microsoft.com/en-us/dotnet/api/system.applicationid?view=net-6.0
Espero ter ajudado, forte abraço!
segunda-feira, 5 de agosto de 2019
Entenda o DOM de uma vez por todas - 1 Introdução
Olá, este poste é o inicio de uma série de postes com um único objecto: "Te ajudar de uma vez por todas à entender o DOM usando javascript". Então bem-vindo a primeira parte:
Introdução ao DOM
O Document Object Model , geralmente chamado de DOM , é uma parte essencial para tornar os sites interativos. É uma interface que permite que uma linguagem de programação manipule o conteúdo, estrutura e estilo de um site. JavaScript é a linguagem de script do lado do cliente que se conecta ao DOM em um navegador da Internet.
Quase sempre que um site realiza uma ação, como alternar entre uma apresentação de slides de imagens, exibir um erro quando um usuário tenta enviar um formulário incompleto ou alternar um menu de navegação, ele é o resultado do JavaScript acessando e manipulando o DOM. Neste artigo, aprenderemos o que é o DOM, como trabalhar com o documentobjeto e a diferença entre o código-fonte HTML e o DOM.
Quase sempre que um site realiza uma ação, como alternar entre uma apresentação de slides de imagens, exibir um erro quando um usuário tenta enviar um formulário incompleto ou alternar um menu de navegação, ele é o resultado do JavaScript acessando e manipulando o DOM. Neste artigo, aprenderemos o que é o DOM, como trabalhar com o documentobjeto e a diferença entre o código-fonte HTML e o DOM.
Nota:
Embora o DOM seja independente de idioma, ou criado para ser independente de uma linguagem de programação específica, ao longo deste recurso, nos concentraremos e nos referiremos à implementação do JavaScript do HTML DOM.
O que eu preciso?
Para entender efetivamente o DOM e como ele se relaciona com o trabalho com a Web, é necessário ter um conhecimento existente de HTML e CSS . Também é benéfico ter familiaridade com a sintaxe e a estrutura de código fundamentais do JavaScript.O que é o DOM?
No nível mais básico, um site consiste em um documento HTML. O navegador que você usa para visualizar o site é um programa que interpreta HTML e CSS e renderiza o estilo, conteúdo e estrutura na página que você vê.Além de analisar o estilo e a estrutura do HTML e do CSS, o navegador cria uma representação do documento conhecido como Document Object Model. Este modelo permite que o JavaScript acesse o conteúdo de texto e os elementos do documento do site como objetos.
JavaScript é uma linguagem interativa e é mais fácil entender novos conceitos fazendo. Vamos criar um site muito básico. Crie um index.htmlarquivo e salve-o em um novo diretório de projeto.
index.html
<!DOCTYPE html>
<html>
<head>
<title>Entendendo o DOM</title>
</head>
<body>
<h1>Document Object
Model (DOM)</h1>
</body>
</html>Para nossos objetivos, usaremos o navegador Google Chrome, mas você poderá receber resultados semelhantes de outros navegadores modernos. No Chrome, abra-se index.html. Você verá um site simples com nosso título dizendo "Document Object Model (DOM)". Clique com o botão direito em qualquer lugar da página e selecione "Inspecionar". Isso abrirá as Ferramentas do desenvolvedor.
Na guia Elements , você verá o DOM.
Nesse caso, quando expandido, parece exatamente o mesmo que o código-fonte HTML que acabamos de escrever - um tipo de documento e as poucas outras tags HTML que adicionamos. Passar o mouse sobre cada elemento destacará o respectivo elemento no site renderizado. Pequenas setas à esquerda dos elementos HTML permitem alternar a exibição de elementos aninhados.
O document object
O document oject é um objeto interno que possui muitas propriedades e métodos que podemos usar para acessar e modificar sites. Para entender como trabalhar com o DOM, você deve entender como os objetos funcionam em JavaScript.Em Developer Tools no index.html , vá para a guia Console . Digite
document
no console e pressione ENTER
. Você verá que o resultado é o mesmo que você vê na guia Elements.
> document;
Saída
#document
<!DOCTYPE html>
<html lang="en">
<head>
<title>Entendendo o DOM</title>
</head>
<body>
<h1>Document Object
Model (DOM)</h1>
</body>
</html>Digitar document e trabalhar diretamente no console não é algo que você geralmente fará fora da depuração, mas ajuda a solidificar exatamente o que o document object é e como modificá-lo, como descobriremos a seguir.
Qual é a diferença entre o código-fonte DOM e HTML?
Atualmente, com este exemplo, parece que o código-fonte HTML e o DOM são exatamente a mesma coisa. Existem duas instâncias em que o DOM gerado pelo navegador será diferente do código-fonte HTML:- O DOM é modificado pelo JavaScript do lado do cliente
- O navegador corrige automaticamente erros no código-fonte
document.body;
O console responderá com esta saída:
Saída
<body>
<h1>Document Object Model (DOM)</h1>
</body>Document
é um objeto, body
é uma propriedade desse objeto que acessamos com notação de ponto. O envio document.body para o console gera o elemento body e tudo dentro dele.No console, podemos alterar algumas das propriedades ativas do objeto body neste site. Vamos editar o atributo style, mudando a cor de fundo para blue. Digite isso no console:
document.body.style.backgroundColor = 'blue';
Depois de digitar e enviar o código acima, você verá a atualização ao vivo para o site, conforme a cor do plano de fundo é alterada.
Alternando para a guia Elements ou digitando document.body no console novamente, você verá que o DOM foi alterado.
Saída
<body style="background-color: blue;">
<h1>Document Object Model (DOM)</h1>
</body>
Nota: Para alterar a propriedade background-color CSS, tivemos que digitar o JavaScript
backgroundColor
. Qualquer propriedade CSS hifenizada será escrita em camelCase em JavaScript
O código JavaScript que digitamos, atribuindo à cor azul como fundo do body, é agora uma parte do DOM.
No entanto, clique com o botão direito do mouse na página e selecione "Ver fonte da página". Você notará que a fonte do site não contém o novo atributo de estilo que adicionamos via JavaScript. O código-fonte ou de origem de um site não será alterada e nunca será afetada pelo JavaScript do lado do cliente. Se você atualizar a página, o novo código que adicionamos no console desaparecerá.
A outra instância em que o DOM pode ter uma saída diferente do código-fonte HTML é quando há erros no código-fonte. Um exemplo comum disso é a tag table – uma tag tbody é necessária dentro de um table, mas os desenvolvedores geralmente não a incluem em seu HTML. O navegador corrigirá automaticamente o erro e adicionará o tbody, modificando o DOM. O DOM também corrigirá tags que não foram fechadas.
O que aprendemos?
Nesta parte, definimos o DOM, acessamos o objeto document, usamos JavaScript e o console para atualizar uma propriedade do objeto document e examinamos a diferença entre o código-fonte HTML e o DOM.No próximo artigo, revisaremos a terminologia HTML importante, aprenderemos sobre a árvore DOM, descobriremos o que são nós, aprenderemos sobre os tipos mais comuns de nós e começaremos a criar scripts interativos com JavaScript.
Fique atento ao proximo artigo desta série!
Forte abraço.
terça-feira, 2 de julho de 2019
Como ignorar a acentuação ao consultar dados no Sql Server?
Vou ser rápido. Mas esse problema ocorre porque a muitas vezes a colecção do Sql Server definida é a Accent Sensitive (AS), por isso ele procurará a expressão exacta, incluindo as acentos.Solução
SELECT * FROM Produto WHERE Nome like '%pao%' COLLATE Latin1_general_CI_AI
Na consulta acima a expressão Latin1_general_CI_AIpode ser dividido nas seguintes partes:
- Latin1 - faz o servidor tratar strings usando charset latin 1, ou seja, o ascii.
- CI - especifica maiúsculas e minúsculas, portanto, "ABC" é igual a "abc".
- AI - especifica insensível à acentuação, então "ãó" é igual a "ao".
quinta-feira, 30 de maio de 2019
Como humanizar o formato dos DateTime em C#
Datas humanizadas são mais fáceis de ler. Eles estão bem formatados. Podemos mostrar "1 hora atrás" ou "1 minuto atrás", em vez do formato padrão, confuso. Hoje quero apresentar apenas um algoritmos que nos ajudarás a obter esse resultado em c#.
O Algoritmo
public static string GetDataHumanizada(DateTime d)
{
// Obtém o intervalo de tempo decorrido até a data actual.
TimeSpan s = DateTime.Now.Subtract(d);
int diasTotal = (int)s.TotalDays;
int segundosTotal = (int)s.TotalSeconds;
// Se o total de dias for superior à 31 dias ou inferior a zero
// retornamos a data inserida no argumento.
if (diasTotal < 0 || diasTotal >= 31)
{
return d.ToShortDateString();
}
if (diasTotal == 0)
{
// Menor que 1 minuto
if (segundosTotal < 60)
{
return "Agora mesmo";
}
// Menor que 2 minutos
if (segundosTotal < 120)
{
return "1 minuto atrás";
}
// Menor que 1 hora
if (segundosTotal < 3600)
{
return string.Format("{0} minutos atrás",
Math.Floor((double)segundosTotal / 60));
}
// Menor que 2 horas
if (segundosTotal < 7200)
{
return "1 hora atrás";
}
// Menor que 1 dia
if (segundosTotal < 86400)
{
return string.Format("{0} horas atrás",
Math.Floor((double )segundosTotal / 3600));
}
}
// Completou um dia
if (diasTotal == 1)
{
return "Ontem";
}
// Menor que 1 semana
if (diasTotal < 7)
{
return string.Format("{0} dias atrás",
diasTotal);
}
// Menos que 1 mês
if (diasTotal < 31)
{
return string.Format("{0} semanas atrás",
Math.Ceiling((double)diasTotal / 7));
}
return null;
}
Como usar?
Deixa-me dar um exemplo rápido de como usar:
static void Main()
{
DateTime dataPublicacao = new DateTime(2019, 5, 30,21,15,36);
//Data de Publicacao é: 30/05/2019 21:15:36
Console.WriteLine(GetDataHumanizada(dataPublicacao));
Console.ReadKey();
// Resultado: 4 minutos atrás
// Onde dada do sistema é: 30/05/2019 21:15:32
}
Conforme o nosso algoritmo está podemos humanizar a data apenas até semanas. Se queres um desafio, altere-o até meses ou mesmo até anos. Espero ter ajudado.
Um forte abraço.
quinta-feira, 25 de abril de 2019
Como gerar sequências numéricas em SQL numa consulta ou select?
Sem muitas voltas, te digo: Use a função Row_Number() do Sql Server.Confira no exemplo a seguir.
Select Row_Number() Over(Order By idAluno) as Ordem, idAluno, NomeAluno
From Aluno
Where idTurma = 2
Resultado:
Isso é tudo, apenas olhe para essa instrução como um modelo para o que realmente desejas, ou comente o para eu te ajudar.
quinta-feira, 11 de abril de 2019
Porque Sql Server está consumindo muita memória? [Resolvido]
Porque o Sql Server está consumindo muita memória?
O problema começa quando instalamos o Sql Server. Ao instalarmos o Sql, normalmente, deixamos as definições padrães da memória mínima e máxima, que varia entre 0MB até 2147483647MB (2 petabytes). Ou seja, ele vai consumir toda memória do teu servidor deixando apenas 5MB livre para rodar outros serviços.
A Solução é limitar a memória máxima do Sql Server.
Neste exemplo vamos limitar a memória máxima para apenas 6144MB que equivale à 6GB.
Primeiramente, entre no Sql Server com um utilizador com permissão administrativa. Sendo assim basta seguir os seguintes passos:
- Clique com o botão direito no servidor conectado;
- Em seguida, clique em Properties (Propriedades);
- Selecione a aba Memory (Memória);
- Edite o campo Maximum Server Memory (Memória máxima do servidor). No nosso exemplo, queremos que o Sql Server consuma apenas 6GB;
- Clique em Ok para confirmar as alteração.
Pronto! Mas se for necessário reiniciar o Sql Server, o faça!
Bonus: Como limitar a memória do SqlServer via código?
Isso é simples! Copia e cola os seguintes comandos:
sp_configure 'max ser',6144
reconfigure
Note que 6144 são os megabytes que equivale a 6GB.
Alguma dúvida? Deixe nos cometário. Espero ter ajudado.
Alguma dúvida? Deixe nos cometário. Espero ter ajudado.
segunda-feira, 28 de janeiro de 2019
Como colocar mensagem no DataList quanto está Vazio (Empty) no asp.net?
Como colocar a mensagem no DataList quanto está Vazio ou Empty conforme se faz no GridView do Asp.net?
O GridView possui a propriedade EmptyDataText que serva para colocar a mensagem de erro ou "not find" mas infelizmente o DataList e o ListView não têm esse propriedade. Para resolver este problema siga a solução abaixo:
<asp:DataList ID="dlFunc" runat="server" RepeatColumns="4">
<ItemStyle CssClass="CardSeparation" />
<ItemTemplate>
<%-- area para campos --%>
</ItemTemplate>
<FooterTemplate>
<asp:Label Visible='<%#bool.Parse((dlFunc.Items.Count==0).ToString())%>'
runat="server" ID="lblNoRecord" Text="Documento não encontrado!"></asp:Label>
</FooterTemplate>
</asp:DataList>
Isso está criando uma lable no rodapé de DataList e torná-lo visível somente se a contagem de registro DataList é 0.
<asp:Label Visible='<%#bool.Parse((dlFunc.Items.Count==0).ToString())%>'
runat="server" ID="lblNoRecord" Text="Documento não encontrado!">
Espero ter te ajudado. Um forte abraço!
segunda-feira, 21 de janeiro de 2019
Entity Framework - Como listar tabela dinamicamente através do seu nome?
public IQueryable GetMyTable(string tipo)
{
MyDbContext context = new MyDbContext();
Type type = Type.GetType($"teu_namespace.{tipo}");
if (type != null)
return context.Set(type).AsQueryable();
return null;
}
O segredo todo está no método Set. Muitas pessoas que encontram esse problema usaram esse método de maneira errada, colocando o Set<Type>. Isso sempre gerá o erro: "is a type but used as a class".
Para evitar esse problema use o Set(string) é a melhor forma para dinamizar o teu código.
sexta-feira, 21 de setembro de 2018
Por que você pode querer usar CGI com C#?
O que é o CGI?
O Common Gateway Interface, ou CGI, é um padrão W3C de longa data para comunicação entre uma página da web e um aplicativo disponível no servidor web. Os aplicativos no servidor que se comunicam no CGI têm todas as funcionalidades de qualquer outro aplicativo nativo, como acesso ao banco de dados ou leitura de arquivos de entrada. No entanto, no mundo atual, com ASP.NET, PHP, Perl e muitas outras linguagens de script que fornecem essencialmente a mesma funcionalidade, você pode se perguntar por que se incomodaria em criar seu próprio aplicativo CGI com C #. Existem algumas razões que posso pensar que podem ser aplicadas.Motivo 1
Primeiro, os interpretadores para ASP, PHP, Perl, etc. são essencialmente aplicativos aproveitando o CGI. Em muitos casos, eles são criados diretamente no serviço da Web (como com ISAPI para IIS), mas todos eles também estão disponíveis em suas aparências CGI (ASP disponível como CGI por meio do projeto Mono da Novel). Para entender melhor os recursos e a limitação da sua linguagem de script favorita do servidor, você pode estar interessado em saber como ela funciona em um nível inferior.Motivo 2
Outra razão é que você pode escrever seu próprio intérprete de mini-scripts. Linguagens como ASP são de propósito geral e, embora possam fazer qualquer coisa, algumas coisas poderiam ser melhor realizadas com um script de propósito mais específico.Por exemplo, isso descreve a razão pela qual eu investiguei pela primeira vez o reino de CGI e C#. Minha empresa tem uma demanda muito alta por relatórios. Apesar de uma ampla gama de ferramentas disponíveis para os funcionários, o site continua sendo o principal recurso para seus relatórios personalizados devido a muitas viagens. Todos os relatórios têm uma variedade de requisitos gráficos muito exigentes, desde formatação, até gráficos, até o fornecimento de uma pasta de trabalho do Excel gerada dinamicamente. O código ASP estava começando a parecer assustador, então criamos um aplicativo C# personalizado para interpretar uma linguagem de relatório tão específica às necessidades de nossos negócios que até mesmo usuários avançados não programadores podem ajudar na criação e modificação das necessidades de relatórios. (Um tópico para outro artigo? diz que sim no comentário.)
Motivo 3
Outro benefício para CGI é que ele é agnóstico do servidor web. O mesmo executável funcionará para o IIS como para o Apache, como para qualquer outro servidor da Web compatível com o W3C. E, ao contrário de algumas linguagens de script, o executável é compilado para que a execução seja rápida e a origem não esteja visível.C# é uma excelente linguagem para usar com CGI por causa do poder do .NET framework. Também é possível testar um aplicativo C# utilizando CGI, mesmo sem um servidor da Web, porque ele simplesmente é executado como um aplicativo de console. Mais sobre isso depois.
Motivo 4
Finalmente, existem provedores de serviços da Web que permitem usar aplicativos CGI personalizados que podem não permitir o uso de módulos Apache ou ISAPI IIS DLLs. O motivo é que um módulo integrado em um servidor da Web pode causar muito mais danos ao servidor da Web do que um executável separado e controlável.Gostou? Comenta o que mais te interessou!
terça-feira, 4 de setembro de 2018
Como ignorar letras acentuadas na comparação de string no C# e SQL?
Ignorar acentos no C#
Para ignorar acentos, maiúsculas e minúsculas, você pode primeiro definir um método de extensão como este:public static string RemoveAcentos(this String s)
{
String normalizedString = s.Normalize(NormalizationForm.FormD);
StringBuilder stringBuilder = new StringBuilder();
for (int i = 0; i < normalizedString.Length; i++)
{
Char c = normalizedString[i];
if (CharUnicodeInfo.GetUnicodeCategory(c) != UnicodeCategory.NonSpacingMark)
stringBuilder.Append(c);
}
return stringBuilder.ToString().ToLower();
}
Exemplo 1
string valor = "pãO 10 Grãos".RemoveAcentos();if (valor == "Pão 10 Grãos".RemoveAcentos())
{
// instruções
Console.WriteLine("Iguais");
}
else
{
// instruções Console.WriteLine("Diferentes");
}
Exemplo 2
string queryText = filter.ToUpper().RemoveDiacritics();var result = from p in Produtos
where p.Nome.ToUpper().RemoveAcentos() == queryText
select p;
Ignorar acentos no SQL
O nosso método, no exemplo 2, é bom se estamos apenas iterando sobre uma colecção no C#, mas se você estiver usando LINQ para SQL é preferível evitar métodos não padrão (incluindo métodos de extensão) em sua consulta LINQ. Isso ocorre porque seu código não pode ser convertido em SQL válido e, portanto, executado no SQL Server com toda a optimização de desempenho.Como não parece haver uma maneira padrão de ignorar os acentos no LINQ para SQL, nesse caso, sugiro alterar o tipo de campo que você deseja pesquisar para não diferenciar maiúsculas e minúsculas (CI_AI):
ALTER TABLE Produtos ALTER COLUMN Nome [varchar](100) COLLATE SQL_Latin1_General_CP1_CI_AI
Sua consulta deve agora ignorar a acentuação e o caso.
É importante que você deve remover temporariamente quaisquer restrições exclusivas no campo antes de executar a consulta acima usando, por exemplo, a seguinte instrução:
ALTER TABLE People DROP CONSTRAINT UQ_Produtos_Nome
Agora a nossa consulta LINQ será simplificada:
var result = from p in Produtos
where p.Nome == filter
select p;
Espero ter ajudado.
sexta-feira, 31 de agosto de 2018
Como exportar Crystal Report para PDF e Excel (código completo)
Vamos aprender, de forma rápida, como exportar um relatório de Crystal Report para os formatos PDF e Excel. Como exemplo vou pegar o projecto que fizemos no post anterior. Clica aqui para ver.Adicione os botões "Exportar PDF" e "Exportar Excel" no formulário para exportar o relatório.
Para o botão "Exportar PDF" coloque o seguinte código:
private void btnExportToPDF_Click(object sender, EventArgs e)
{
SaveFileDialog dialog = new SaveFileDialog();
dialog.Filter = "Arquivo PDF|*.pdf";
string nomeArquivo="";
if(dialog.ShowDialog()== DialogResult.OK)
{
nomeArquivo = dialog.FileName;
cr.ExportToDisk(ExportFormatType.PortableDocFormat, nomeArquivo);
}
}
Para o botão "Exportar Excel" coloque o seguinte código:
private void btnExportToExcel_Click(object sender, EventArgs e)
{
SaveFileDialog dialog = new SaveFileDialog();
dialog.Filter = "Arquivo Excel|*.xls";
string nomeArquivo = "";
if (dialog.ShowDialog() == DialogResult.OK)
{
nomeArquivo = dialog.FileName;
cr.ExportToDisk(ExportFormatType.Excel, nomeArquivo);
}
}
Como podemos ver, para os dois botões, colocamos um SaveFileDialog para o utilizador poder escolher a pasta e o nome do arquivo.
Executa o programa e testa cada botão. Espero te ajudado.
public partial class FormPaises : Form
{
public FormPaises()
{
InitializeComponent();
}
Reports.ReportPaises2 cr = new Reports.ReportPaises2();
private List<Pais> GetListaPaises()
{
List<Pais> Paises = new List<Pais>
{
new Pais(1, "Angola"),
new Pais(2, "Brasil"),
new Pais(3, "Portugal"),
new Pais(6, "Moçambique"),
new Pais(7, "Cabo-Verde"),
new Pais(8, "Namibia")
};
return Paises;
}
private void FormPaises_Load(object sender, EventArgs e)
{
crystalReportViewer1.ReportSource = cr;
cr.SetDataSource(GetListaPaises());
}
private void btnExportToPDF_Click(object sender, EventArgs e)
{
SaveFileDialog dialog = new SaveFileDialog();
dialog.Filter = "Arquivo PDF|*.pdf";
string nomeArquivo="";
if(dialog.ShowDialog()== DialogResult.OK)
{
nomeArquivo = dialog.FileName;
cr.ExportToDisk(ExportFormatType.PortableDocFormat, nomeArquivo);
}
}
private void btnExportToExcel_Click(object sender, EventArgs e)
{
SaveFileDialog dialog = new SaveFileDialog();
dialog.Filter = "Arquivo Excel|*.xls";
string nomeArquivo = "";
if (dialog.ShowDialog() == DialogResult.OK)
{
nomeArquivo = dialog.FileName;
cr.ExportToDisk(ExportFormatType.Excel, nomeArquivo);
}
}
}
Código completo deste projecto.
public partial class FormPaises : Form
{
public FormPaises()
{
InitializeComponent();
}
Reports.ReportPaises2 cr = new Reports.ReportPaises2();
private List<Pais> GetListaPaises()
{
List<Pais> Paises = new List<Pais>
{
new Pais(1, "Angola"),
new Pais(2, "Brasil"),
new Pais(3, "Portugal"),
new Pais(6, "Moçambique"),
new Pais(7, "Cabo-Verde"),
new Pais(8, "Namibia")
};
return Paises;
}
private void FormPaises_Load(object sender, EventArgs e)
{
crystalReportViewer1.ReportSource = cr;
cr.SetDataSource(GetListaPaises());
}
private void btnExportToPDF_Click(object sender, EventArgs e)
{
SaveFileDialog dialog = new SaveFileDialog();
dialog.Filter = "Arquivo PDF|*.pdf";
string nomeArquivo="";
if(dialog.ShowDialog()== DialogResult.OK)
{
nomeArquivo = dialog.FileName;
cr.ExportToDisk(ExportFormatType.PortableDocFormat, nomeArquivo);
}
}
private void btnExportToExcel_Click(object sender, EventArgs e)
{
SaveFileDialog dialog = new SaveFileDialog();
dialog.Filter = "Arquivo Excel|*.xls";
string nomeArquivo = "";
if (dialog.ShowDialog() == DialogResult.OK)
{
nomeArquivo = dialog.FileName;
cr.ExportToDisk(ExportFormatType.Excel, nomeArquivo);
}
}
}
Pesquisar neste blogue
Com tecnologia do Blogger.