Jump to content

c#prog school


ads_weez
 Share

Recommended Posts

fazes replace do caracter de NewLine

Por muito mais que que estude só aprendo uma coisa, que ainda tenho muita coisa para aprender.

A beleza de um código está em decompor problemas complexos em pequenos blocos simples.

"learn how to do it manually first, then use the wizzy tool to save time."

"Kill the baby, don't be afraid of starting all over again. Fail soon, learn fast."

Link to comment
Share on other sites

fazes replace do caracter de NewLine

problema que o meu codigo esta em função de var.

vou te mandar

para ver se consegues saber onde colocar a instrução

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading;
using System.IO;
using System.Timers;
using System.Data.OleDb;
using System.Text.RegularExpressions;
using System.Windows.Forms;
namespace WindowsFormsApplication1
{
public partial class Livro : Form
{
	private int _ticks;
	public Livro()
	{
		InitializeComponent();
		//da inicio ao contador
		Contador.Start();

	}
	//caminho do documento de texto
	public string caminhoArquivo = "ESSJT4_alterado.txt";

	public class Salva
	{  
		//variavel de armazenação
		public string Nome { get; set; }
		public string Cota { get; set; }
		public string ClassUniversal { get; set; }
		public string Autr { get; set; }
	}
	private void Contador_Tick(object sender, EventArgs e)
	{
		try
		{
			//incrementa o contador
			_ticks++;
			//apresenta o contador
			this.Text = _ticks.ToString();

			//funcão if quando contador chegar 60 elimina os registos
			if (_ticks == 60)
			{
			   //actualiza o programa
				this.Refresh();
				//ligação a base de dados e elemina todos os registos para depois ser inserido novamente(prevenção de erro chave duplicados)
				OleDbConnection conn = new OleDbConnection(@"Provider=Microsoft.ACE.OLEDB.12.0;Data Source=Registos.accdb");
					  conn.Open();
					OleDbCommand cmd = new OleDbCommand("delete * from Aula7",conn);
					cmd.ExecuteNonQuery();
					conn.Close();
					this.Text = "Actualizado";

				}

			else
				//ao chegar 60 ou 61 executa a acção(preencher a Base de dados)
				if (_ticks>= 60)
				{
					string dtr = caminhoArquivo;
					dtr.Contains("*");

						var consulta = from linha in File.ReadAllLines(caminhoArquivo)
									   let dads = linha.StartsWith("#") //começa ler quando encontrar(#)
									   let Dados = linha.Split('#') //separa-os por (#)
										where Dados.Length > 12 //informa que array é maior que 12
										let kiks=linha.Split('\n')
										let termi=linha.EndsWith(dtr.ToString())
									   select new Salva()
									  {
										  Nome = Dados[3], //obtem os valores na posição3
										  ClassUniversal = Dados[7],
										  Autr = Dados[8],
										  Cota = Dados[12]
									  };

						foreach (var item in consulta)
						{
							OleDbConnection conn = new OleDbConnection(@"Provider=Microsoft.ACE.OLEDB.12.0;Data Source=Registos.accdb");
							OleDbCommand cmd = new OleDbCommand();
							conn.Open();
							//ligação a base de dados
							cmd.Connection = conn;
							cmd.CommandText = @"INSERT INTO Aula7 ([Nome], [Autor], [Cota], [Class Decimal Universal]) VALUES (@Nome, @Autor, @Cota, @ClassUniversal)";
							//inseri os registos
							cmd.Parameters.AddWithValue("@Nome", item.Nome.ToString());
							cmd.Parameters.AddWithValue("@Autor", item.Autr.ToString());
							cmd.Parameters.AddWithValue("@Cota", item.Cota.ToString());
							cmd.Parameters.AddWithValue("@ClassUniversal", item.ClassUniversal.ToString());
							cmd.ExecuteNonQuery();
							//apresentação dos registos em DataGridView
							string datagrida = "Select* from Aula7";
							OleDbDataAdapter adapat = new OleDbDataAdapter(datagrida, conn);
							DataSet DSet = new DataSet();
							DSet.Clear();
							adapat.Fill(DSet);
							MostraTabela.DataSource = DSet.Tables[0].DefaultView;
							conn.Close();
							_ticks = 0;
						}

				}
		}
			//prevenção dos erros
		catch (OleDbException s)
		{
			MessageBox.Show(" Erro : " + s.Message);
		}
		catch (Exception ex)
		{
			MessageBox.Show(" Erro : " + ex.Message);
		}
	}
	}
}
Link to comment
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now
 Share

×
×
  • Create New...

Important Information

By using this site you accept our Terms of Use and Privacy Policy. We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue.