26 noviembre 2011

5 habilidades que debes de desarrollar para ser mejor programador.


Para ser un buen programador lo menos importante es saber muchos lenguajes de programación. Lo esencial, y a lo que hay que aprender, es a plantear y diseñar las mejores soluciones ante un problema. Por esta razón vamos a apreder 5 habilidades con el fin de ser mejores programando:

1. CREATIVIDAD:
Esta habilidad de suma importancia consiste en tener la imaginación para ver mentalmente la solución a un problema planteándola como algoritmo.

2. ORGANIZACIÓN MENTAL:
Ser despistado y no tener bien organizadas las ideas es un gran inconveniente. Es importante tener las ideas claras porque así se sabrá qué pasos seguir sin perderse por el camino.

3. TENER MENTE ABIERTA:
No hay que tener la mente cuadrada pensando que para conseguir un objetivo sólo hay una solución. Al contrario, siempre hay varias.

4. SER AMBICIOSO:
No hay que agobiarse por obtener errores. Ni mucho menos abandonar. Al contrario hay que ser constante. En informática lo más probable es que obtengas un error así que hay que estar preparado para solventarlo.

5. SER CURIOSO:
Si te quedas con lo que ya sabes sin tener la sana curiosidad de aprensder más no serás buen programador. Aquí lo ideal es estar abierto, querer mejorar aprendiendo metodologíaas más eficientes, y escuchar siempre consejos que ayuden.

Saludos, Victor

P.D.: La idea la saque de aquí: http://www.vidamrr.com

18 noviembre 2011

Cálculo de la diferencia en horas y minutos de dos horarios




Estaba meditando como resolver un código que me calculase la diferencia entre dos horas cuando se terminó la jornada laboral. Entonces decidí que tal código lo haría en Python como práctica de un aprendizaje.

Y cómo no, tras un ratejo en el que he disfrutado con Python (ese lenguaje que no gusta a mis compañeros de trabajo al punto del que no le ven ni uso ni futuro), he resuelto el código necesario.








Perdonen por haber puesto en una imagen el códigio fuente pero lo hice por causas mayores: El operador de comparativa (>) era confundido con los delimitadores de las etiquetas de HTML.

El código podria tener más complejidad, pero por hoy esta perfecto. Mañana más.

Saludos!

08 octubre 2011

Ejercicio hecho en C # que carga en una combo subcadeenas escritas en un textbox y separadas por ;

Este ejercicio, como reza el titulo del articulo, consiste en cargar en la combo cmbDatos, las palabras delimitadas por ; que se escriben en txtString.
El uso del ArrayList lista es puramente para mi comodidad porque así, cuando probaba la aplicación iba corroborado que subcadenas se extraian.

private void btnCargar_Click(object sender, EventArgs e)
{
cmbDatos.Items.Clear();
ArrayList lista = new ArrayList();
string subcadena;
string cadena = txtString.Text;
while (cadena.Length > 0)
{
int indice = cadena.IndexOf(';');
if (indice > 0)
subcadena = cadena.Substring(0, indice);
else
{
subcadena = cadena;
cadena = "";
}
lista.Add(subcadena);
int numeroDeCararteres= (cadena.Length-1) - indice;
if (numeroDeCararteres>-1)
cadena = cadena.Substring(indice+ 1,numeroDeCararteres);


}
for (int i = 0; i < lista.Count; i++)
{
cmbDatos.Items.Add(lista[i].ToString());
}
}

Saludos.

26 agosto 2011

Aclaración entre Menú y Componente / Modulo en Joomla


Como tengo/tenía cierto lio en la cabeza acerca de qué era qué, le pregunté a mi amigo Cheno. Y él, pacientemente me dijo sobre el menú predefinido Este sitio, que:
Eso es un menu, existente en la zona de administracion. Puedes gestionar los menus, poner el nombre que quieras, los elementos que tienen. También los puedes desactivar si quieres

Y sobre la posibilidad de crear un menú yo mismo me dijo:
"Eso en la zona de modulos si no recuerdo mal. Ah pues en donde los menus puedes crear otro. Y luego activarlo y darle una posicion en la zona de componentes y modulos. No recuerdo si se considera un componente o un modulo
pero por ahi aparecera"

Y hasta aquí una breve aclaración.



Árbol en Joomla


Mi idea es realizar una página web en Joomla para promocionar objetos a la venta. Mayorritariamente antigüedades.

En este preciso momento me ronda por la cabeza hacer un menú desplegable (que funcione como un árbol) y donde se vayan desplegando ramificaciones con forme interese. Por ejemplo, las dos ramas principales serian Vehículos y Antigüedades. De la primera se colgarian Turismos, Furgonetas, Motocicletas. De la segunda, Armarios, Televisores, Teléfonos. Y así hasta que yo quisiese seguir prfundizando.

Este enlace conduce a un foro donde se proponen componentes para el fin que tyo persigo:
http://www.joomlaspanish.org/foroEnlaces/showthread.php?t=2839


01 agosto 2011

Herramientas para desarrollar un sitio web

Con eso de que quiero irme de putas y no tengo dinero para ello estoy pensando desarrollar sitios web para ir ganando dinero en un futuro. Paara empezar a profesionalizarme, y hoy que el monitor de mi puesto de trabajo no funciona, investigué sobre herramientas para hacer webs locales, probarlas y luego subirlas a Internet.


Me hablaron de XAMPP, he aquí webs que informan de ello:

Me hablaron de EasyPHP

También de Joomla, pero fue hace mucho tiempo (sus enlaces están en esta misma página web, en la sección Mundo Joomla).


Por internet localicé esto http://es.wix.com/eteam1/fish_build_a_free_flash_websit?utm_campaign=ma_carlosleopoldo.com&experiment_id=ma_carlosleopoldo.com_es Sirve para hacer sitios web con flash


Saludos ;)

03 junio 2011

Ideas para el manejo de reports con DevExpress: orientación y tipo de hoja

Entre PageKind (propiedad que permite elegir entre muchos formatos de hoja. Por citar ejemplos A2, A3, A4, A5,...) y Landscape (vale true si la orientación es vertical y false cuando es horizontal) se puede dar un formato u otro al report final.

26 mayo 2011

Función SQL que devuelve el numero de coincidencias de un caracter en una cadena

Funcíon SQL que devuelve el numero de coincidencias de un caracter en una cadena

CREATE FUNCTION [dbo].[fnCountChar] ( @pInput VARCHAR(max), @pSearchChar CHAR(1) )

RETURNS INT
BEGIN

DECLARE @vInputLength INT
DECLARE @vIndex INT
DECLARE @vCount INT

SET @vCount = 0
SET @vIndex = 1
SET @vInputLength = DATALENGTH(@pInput)

WHILE @vIndex <= @vInputLength
BEGIN
IF SUBSTRING(@pInput, @vIndex, 1) = @pSearchChar
SET @vCount = @vCount + 1

SET @vIndex = @vIndex + 1
END

RETURN @vCount

END

08 mayo 2011

En C sharp, seleccionar registros en una base de datos Access (versión 97) usando las librerias ODBC


Aqui escribo el ódigo para seleccionar el máximo valor de un campo determinado:

private void IdMasAlto()
{
DatosConexionABaseDeDatos odatosConexion = new DatosConexionABaseDeDatos();
OleDbConnection conexion = odatosConexion.getConexion();
conexion.Open();
DataSet ds = new DataSet();
DataTable dt = new DataTable();

string strSQL = "SELECT MAX(IdTipo) AS ultimo FROM Tipo";
//La consulta únicamente devolverá un registro de una columna: Un valor.
OleDbDataAdapter oAdaptador= new OleDbDataAdapter(strSQL, conexion);
oAdaptador.Fill(ds, "elultimo");
dt = ds.Tables["elultimo"];
DataRow fila =dt.Rows[0];
//ID es una propiedad
ID = Convert.ToInt32(fila["ultimo"].ToString());
conexion.Close();
}

Este códigio, modificandolo, servirá para recorrer varios registros devuelvos. Quedando así: if (dt.Rows.Count == 0)
this.lblUsuario.Text = "No existe el usuario...";
else
{
foreach (System.Data.DataRow fila in dt.Rows)
{
this.lblUsuario.Text = "Bienvenido " + fila["nombre"].ToString();
}

}



Por supuesto, y antes de marchar, recordar que hay que hacer las siguientes importaciones antes de empezar, en las primeras líneas:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Data;
using System.Data.OleDb;



Saludos ;)

12 abril 2011

C Sharp, en una función contructora no debe faltar,...


...la llamada a la función InitializeComponent() porque de no hacerlo luego nos surgirán errores de código que nos informarán de que, los objetos, del formulario o del report, no han sido construidos.

31 marzo 2011

Curiosidades de C Sharp y SQL (1)

El otro día me descuerné pensando qué podría estar equivodo en esta sentencia SQL, ¿y adivinan el error?:

string SQL = "INSERT INTO Programa (Nombre, Anio, Version, Tipo, EnISO, InstaladoEnPortatil, InstaladoEnPC, Observaciones, Descripcion, Fabricante, CuandoCaduca, EsLibre, ParaWindows, ParaLinux, ParaMacintosh, ConCrack, Serial, Usuario, Password) VALUES ('" + _programa.nombre.ToUpper() + "', '" + _programa.anio + "', '" + _programa.version + "', " + _programa.codTipo + ", " + _programa.enISO + ", " + _programa.instaladoEnPortatil + ", " + _programa.instaladoEnPC + ", '" + _programa.observaciones + "', '" + _programa.descripcion + "', '" + _programa.fabricante + "', '" + _programa.cuandoCaduca + "', " + _programa.esLibre + ", " + _programa.paraWindows + ", " + _programa.paraLinux + ", " + _programa.paraMacintosh + ", " + _programa.conCrack + ", '" + _programa.serial + "', '" + _programa.usuario + "', '" +_programa.password + "')";

¿Ya la han ojeado bien?

Pues el problema era que Password al ser una palabra reservada no se puede utilizar como nombre para un campo de una tabla con base de datos Access. Entonces probé a cambiarla por ClaveDeAcceso, y el error, Instrucción SQL erronea, se esfumó.

Saludos.

19 marzo 2011

En C sharp, eliminar registros en una base de datos Access (versión 97) usando las librerias ODBC


Aqui escribo el ódigo para modificar un registro utilizando las mismas herramientas y lois mismos métdos que seusaron para hacer la inserciónen el articulo En C sharp, insertar registros en una base de datos Access (versión 97) usando las librerias ODBC

Al igual que en el anterior, importo las siguientes librerias:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Data;
using System.Data.OleDb;

y trabajo en la clase Tipo.


public void Eliminar(Tipo _tipo)

{
DatosConexionABaseDeDatos odatosConexion = new DatosConexionABaseDeDatos();
OleDbConnection conexion = odatosConexion.getConexion();
string eliminarSQL = "DELETE FROM Tipo WHERE IdTipo=" + _tipo.id;
conexion.Open();
OleDbDataAdapter oAdaptador = new OleDbDataAdapter(eliminarSQL, conexion);
OleDbCommandBuilder oBuilder = new OleDbCommandBuilder(oAdaptador);

DataSet oDsTipo = new DataSet("Tipo");
oAdaptador.Fill(oDsTipo, "Tipo");
conexion.Close();
}

Este mantiene diferencias con el sucesor, como que nunca se seleccionan todos los campos, y en cambio se ejecuta una sentencia DELETE. Además se ahorran las líneas donde se creabe un objeto Row agregandose como nuevo, porque obviamente esto no añade sino que suprime registros que ya existen.




En C sharp, modificar registros en una base de datos Access (versión 97) usando las librerias ODBC


Aqui escribo el ódigo para modificar un registro utilizando las mismas herramientas y lois mismos métdos que seusaron para hacer la inserckión en el articulo En C sharp, insertar registros en una base de datos Access (versión 97) usando las librerias ODBC

Al igual que en el anterior, importo las siguientes librerias:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Data;
using System.Data.OleDb;

y trabajo en la clase Tipo.

Sin más preámbulos aquí está el código para modificar un registro.

public void ModificarTipoExistente(Tipo _tipo)
{
DatosConexionABaseDeDatos odatosConexion = new DatosConexionABaseDeDatos();
OleDbConnection conexion = odatosConexion.getConexion();
string updateSQL = "UPDATE Tipo SET Descripcion='" + _tipo.descripcion + "', Tipo='" + _tipo.tipo + "' WHERE IdTipo=" + _tipo.id;
conexion.Open();
OleDbDataAdapter oAdaptador = new OleDbDataAdapter(updateSQL, conexion);
OleDbCommandBuilder oBuilder = new OleDbCommandBuilder(oAdaptador);

DataSet oDsTipo = new DataSet("Tipo");
oAdaptador.Fill(oDsTipo, "Tipo");


conexion.Close();

}

Este mantiene diferencias con el sucesor, como que nunca se seleccionan todos los campos, y en cambio se ejecuta una sentencia UPDATE. Además se ahorran las líneas donde se creabe un objeto Row agregandose como nuevo, porque obviamente esto no añade sino que actualiza registros que ya existen.


13 marzo 2011

En C sharp, insertar registros en una base de datos Access (versión 97) usando las librerias ODBC


Ayer, tras muchas horas buscando por Internet un ejemplo válido de cómo agregar registros en una base de datos Access, versión 97, utilizando las funciones de las librerias ODBC, di, al rededor de las 6 de la tarde con esta página web 32.36.2.Use DataTable to insert a Row

Aquí dejo mí codigio, logrado en base a esa página que os he dicho:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Data;
using System.Data.OleDb;


namespace GesPro.Tipo
{
class Tipo
{
string tipo;
string descripcion;
//constructor sin parametros de la clase
public Tipo()
{
this.descripcion = "";
this.tipo = "";
}
//constructor con parametros de la clase
public Tipo(string _tipo, string _descripcion)
{
this.descripcion = _descripcion;
this.tipo = _tipo;
}
// función que inserta nuevos regisrtros en la tabla Tipo de la base de datos GesPro.mdb
public void InsertarNuevoTipo(Tipo _tipo)
{
string ruta = System.IO.Directory.GetCurrentDirectory() + @"\GesPro.mdb"; //indica la ruta donde está la base de dxatos
string cadenaDeConexion = @"Provider=Microsoft.JET.OLEDB.4.0;" + @"data source=" + ruta; //establece cadena de conexión con la base de datos
OleDbConnection conexion = new OleDbConnection(cadenaDeConexion); //creo un objeto conexion
string seleccionarTodosLosRegistros = "SELECT * FROM Tipo";
conexion.Open(); //abro conexión
OleDbDataAdapter oAdaptador = new OleDbDataAdapter(seleccionarTodosLosRegistros,conexion); //creo un adaptador con una sql que selecciona todos los registros
OleDbCommandBuilder oBuilder = new OleDbCommandBuilder(oAdaptador);

DataSet oDsTipo = new DataSet("Tipo"); //creo un objeto dataset
oAdaptador.Fill(oDsTipo,"Tipo");
DataTable oTablaTipo = oDsTipo.Tables["Tipo"]; //creo una tabla para datos y le añado el nuevo registro campo a campo
DataRow oRow = oTablaTipo.NewRow();
oRow["Tipo"] = _tipo.tipo;
oRow["Descripcion"] = _tipo.descripcion;
oTablaTipo.Rows.Add(oRow);
oAdaptador.Update(oDsTipo, "Tipo"); //actualizo el objeto adaptador

conexion.Close();
}

}

}

07 enero 2011

24 noviembre 2010

Primer apunte sobre fotografía: ¿cómo arreglar una foto que está borrosa?



Es fácil:
1º Abres la imagen con el Photoshop y luego la guardas con formato PSD.
2º. Luego se duplica la capa, y en el menú de capas, donde pone Modo de fusión eliges entre "Luz fuerte" o "Luz suave"si hay tonos de piel.
3º. Después ve al menú Filtros, Otros, Paso alto, y le pones un valor de 2,5.

Este consejo lo leí aqui, asique no fue idea mia.

01 noviembre 2010

¿Para qué sirve la función TOP en SQL Server 2005?



En el trabajo me mandaron hacer una vista (utilizando SQL Server 2005) y sin que yo escribiera nada que incitase a la aplicación a escribir TOP 100 PORCENT, el editor la escribia, y aún yo borrándola, volvía a ponerla. Preegunté a mis compañeros y estos me dijeron que buscase en Google, y así hice. Entonces encontré este enlace: Que es el TOP 100 PERCENT de SQL Server. Y ahí descubrí que TOP 100 PORCENT es una nueva funcionalidad que nos visualiza un porcentaje de columnas que cumplan la condición solicitada. Obviamente 100 nos visualizará todas, y 50 la mitad.


La sintaxis de la función TOP es:
SELECT TOP limite_de_filas FROM MyTable.
En este caso, con TOP hemos limitado a un número exacto el limite de filas que queremos que sean devueltas.

SELECT TOP limite_de_filas PERCENT * FROM MyTabla
En este caso, ya usando PERCENT, limitamos al el número de filas con un porcentaje como limite.

Lo malo es que ORDER BY y TOP son ligeramente incompatibles porque al combinar con PORCENT. Y para que su funcionamiento sea positivo uno tiene que hacer cosas como esta:

SELECT * FROM (SELECT TOP 99 PERCENT * FROM T ORDER BY col1) AS A


Para profundizar más vayan al enlace que meniono arriba.

09 octubre 2010

Probables soluciones para arreglar los puertos USB

Mi amigo Salva tiene en su casa un ordenador al que no le marchan los puertos USB, detectando a veces un dispositivo conectado, y otras no.

Aquí os dejo posibles solucione que hayé en esta web:
No me funcionan los puertos USB... AYUDA, DESESPERACIÓN!!! - :

1. Probaremos a actuaizar los controladores. Ve a administrador de dispositivos y busca controladores de bus serie universal (USB). Te saldrá un asistente que te buscará e instalará los drivers.

2. También tienes un solucionador de problemas ahí. ve a
Panel de control-rendimiento y mantenimiento-herramientas administrativas-administracion de equipos y administrador de dispositivos.

3. En última instancia puedes desinstalar e instalar (el conrolador) y quizas así entren en funcionamiento.



Salu2

26 septiembre 2010

En C#: Gestor de directorios

Basandome en En C#: Cómo montar un navegador en un TreeView ( 2º versión) hice los apaños necesarios para que ahora me sacara los subdirectorios del direwctorio raiz llamado Documentos y ubicado dentro de la carpeta Debug del proyecto. Algo que se hace así:
Application.StartupPath + "\\Documentos";
Si, y es esa barra, y no esta /. Aviso porque luego la piciamos confundiendonos con Linux.


Las diferencias enrtre un proyecto y otro son:


1. Ahora cargo el contenido de una carpeta, sus subdirectorios. Utilizando como nodo-raiz uno que tenga por ruta la ruta-inicial, que vale la concatenación de Application.StartupPath más el nombre del directorio raiz. Para el nombre del nodo-raiz, poodemos usar la \tipica o el nombre de la carpeta contanedora. Anteriormente, en la segunda versión, usabamos una función que cargaba los drivers, ahora no, ahora cargamos los subdirectorios. Así:

public void Inicio2()

{
//lo primero, cargsr el contenido de la carpeta raiz
rutaInicial = Application.StartupPath + "\\Documentos";

DirectoryInfo dirInf = new DirectoryInfo(rutaInicial);
try
{
foreach (DirectoryInfo subdir in dirInf.GetDirectories())
{
//de cada directorio se obtiene el nombre y el fullname y se convierte a nodo. El nodo se agrega al principal
SuperTreeNode nodo = new SuperTreeNode();
nodo.Text = subdir.Name;
nodo.Ruta = subdir.FullName;
NodoRaiz.Nodes.Add(nodo);
StateLblInformacion.Text = "";
}
}
catch (Exception ex)
{
//en la barra de estado uestro los errores q se pueden gnerar (falta de derechos o unidad no lista)
StateLblInformacion.Text = ex.Message;

}
}

2. La otra diferencia importante, no es nada del otro mundo: deshabilitar el botón que permite suprimir un directorio y la opción del menú contextual. Y esto se hace en el evento AfterSelect del control TreeView. Así:

if (NodoSeleccionado.Ruta.CompareTo(NodoRaiz.Ruta) == 0)
BtnBorrarDirectorio.Enabled = false;
else
BtnBorrarDirectorio.Enabled = true;
MenuItemBorrarDirectorio.Enabled = BtnBorrarDirectorio.Enabled;



Saludos.

19 septiembre 2010

Cómo quitar del Windows la seguridad UAC


Cinco secillos pasos para deshacernos de las pesadas preguntas que Windows nos hace para evitar posibles cagadas:

1º. Vamos a Panel de control.
2º Cuentas de usuario.
3º Clicamo en Activar o desactivar el control de cuentas del usuario-.
4. Wala! Desactivamos la casilla de Usar el control de cuentas de usuario (UAC) para ayudar a proteger el equipo.
5º Tras esto, al pulsar el botón Aceptar nos preguntará si queremos reiniciar ahora o más tarde. Tras el reincio el Windows Vista, o 7, porque para sendos es igual, no será tan protector.


El dibujo lo saqué de esta web.

Saludos.

08 septiembre 2010

Reparar el acceso a internet en un Windows Vista

Tuve que arreglarle el ordenador a una amiga porque no tenía acceso a nternet usando su Windows Vista. Entonces busqué en Google y localicé esta web. En ella su propietario, mil gracias, nos indica que vayamos al Simbolo del sistema (ir a administración), y antes de abrirlo para meter comando, clicar sobre el icono con el botón derecho para abrirlo como Ejecutar como Administrador. Después, ya dentro, tecleen netsh winsock reset. Tras la ejecución del programa, deberás reiniciar el ordenador. Y walá! Funciona! Y sin rezar a dios.

Esta averia pudo suceder si se coló un virus. Con lo cual tras el reinicio, pase su anivirus para limpiar su pc de troyanos, gusanos y demás guarradas.

Cuando ejecutamos el comando netsh winsock reset, este limpia y resetea al estado de configuración por defecto, elimina todos los LSP (Layered Service Providers) previamente instalados, incluyendo el potencial LSP causante del mal funcionamiento para la conexión de red o internet.

Saludos y gracias al autor del blog, Gabriel Carpio por su aportación.


ANEXO ¿Qué es un Layered Service Provider (LSP)?: Layered Service Provider (LSP) es una característica de Microsoft Windows Winsock 2 Service Provider Interface (SPI).Layered Service Provider es una DLL que usa Winsock API para insertarse en la pila de TCP/IP. Una vez en la pila, un Layered Service Provider puede insertar y modificar entradas y salidas de tráfico de Internet. Esto pemite procesar todo el tráfico TCP/IP que tiene lugar entre la Internet y aplicaciones que están accesando Internet (tales como un navegador web, un cliente de correo electrónico, etc).

Sacado de la Wikipedia.

05 septiembre 2010

Consejos de Rodrigo para futuro código con ASP, JavaScript, C Sharp, componentes Devexpress y no recuerdo qué más

El viernes el colega de trabajo Rodrigo se pasó buen rato ayudandome a resolver un código sencillo, pero repleto de errores por mi novatez.

Primero, el código javascript se tiene que separar de los archivos aspx porque así se gana limpieza. Estos nuevos archivos se llamarán como los aspx pero con extensión js. Y serán incluidos en los archivos form. De esta manera, siendo esto un ejemlo:

Y ojito con qué nombre ponen a ClientInstanceName, porque en los .js, a las variables de los asp, se las conoce por ese nombre. Se sugiere que el ID de un control y el clientinstancename sean el mismo.

Segundo, javascript es C. Sin enbargo, como en nuestro caso usamos herramientas DevExpress, tendremos que usar los métodos de estas herramientas. Para saber cuales son, pues vamos a la ayuda, y allí tecleamos el nombre del control.

Tercero, ah! Ojo, ojito... No podemos usar un visible común. Sino, que tenemos que usar un clientVisible. Porque la tenemos que visualizar o dejar de hacerlo, de lado del cliente, y no del lado del servidor. En tonces si usamos Visible, nos va a fallar.

Consejo, no vayan de listos, y... Otra cosa, observen si el navegdor seleccionado no dibuja una señal de advertencia.. Porque si lo hace, en el código tienen un error, aunque no se haya detectado en el depurador.

Otros consejos, pero de diseño: usen tablas, y siempre con el mismo número de columnas. Y otra cosa. Uff, no paro. Utilicen y reutilicen UserForm, porque así les va a cundir más.


Saludos.

23 agosto 2010

Traducir componentes DevExpress


Estaba de los nervios esta mañana por no poder lograr este objetivo: traducir los componentes DevExpress del inglés al castellano, cuando mi supervisor a las 12.30 ha acudido a recatarme. Le he explicado qué quería hacer y me ha llamado melón (en su argot: tonto). Al momento ha cogido el mouse y se ha puesto a teclear en google y ha encontrado cómo hacerlo. Yo flipaba pensando qué del modo que él lo estaba haciendo se ahorraban muchos calentamientos de cabeza, a la par, que quedaba más profesional. Pero no logré quedarme muy bien con la coplilla, así que ahora, a las 16.51, me puse a buscar la soluciónj en google. No sé si será la misma.

Encontré esto, escrito en C sharp:
1. Añadir dos lineas para especificar el idioma en el proyecto (form_load):
// Necesario para traducir los componentes a Español
/*1º linea*/
System.Threading.Thread.CurrentThread.CurrentCulture =
new System.Globalization.CultureInfo("es-ES");
/*2º linea*/
System.Threading.Thread.CurrentThread.CurrentUICulture =
new System.Globalization.CultureInfo("es");
2. Añadir la carpeta con los resources en la raíz del proyecto. Esta carpeta la puedes conseguir en el sitio oficial de DevExpress, donde deberás seleccionar el idioma deseado y tu versión de DevExpress.

Los pasos los he copiado literalmente de http://www.joselite.com/traducir-componentes-devexpress. Al que pido perdón si molesto. Y doy gracias por su ayuda.

21 julio 2010

El proyecto Bouncy Castle

¡Genial, en el curso deel DNIe a se habla de programción!

La imagen promociona el proyecto Bouncy Castle, que ya se puede descargar en su web oficial, de software libre que desarrolla una serie de librerías criptográficas libres y, entre otros, ofrece un provider para el JCE de Java.

Además del código del proyecto se puede encontrar una extensa documentación así como diversos ejemplos de uso de las librerías.

Además de la implementación de un provider JCE para usar en Java también contiene otras utilidades que pueden ser de interés a la hora de hacer una aplicación basada en el DNI electrónico, especialmente si se quieren implementar servicios de valor añadido. Las más relevantes son:

  • Librería para leer y escribir objetos codificados en ASN.1
  • API para comunicaciones TLS de cliente
  • Generador de Certificados X.509, CRLs y ficheros PKCS#12
  • Generación de Certificados de Atributos
  • Generación y procesado de objetos S/MIME y CMS (PKCS#7/RFC 3852)
  • Generación y procesado de consultas OCSP (RFC 2560)
  • Generación y procesado de sellos de tiempo TSP (RFC 3161)
  • Generación y procesado de objetos OpenPGP (RFC 2440).


Señores, no dispongo de tiempo por l momento, aí pes, dejo este tema a mitad, para abordr cuando sepa más.

SALUDOS :P


______________________

A continuación se muestra un ejemplo de aplicación realizada en Java usando los servicios criptográficos del provider Bouncy Castle en lugar del provider por defecto que viene en el sistema.

La aplicación en cuestión realiza el Hash (resumen criptográfico) de un fichero de texto en claro.

EJEMPLO de código:

/* Cargar "provider" */

Security.addProvider(new BouncyCastleProvider());

/* Crear función resumen, SHA-1 en el ejemplo */

MessageDigest messageDigest = MessageDigest.getInstance("SHA");

/* Leer fichero de 1k en 1k y resumir*/

byte[] buffer = new byte[1000];

FileInputStream in = new FileInputStream();

int leidos = in.read(buffer, 0, 1000);

while (leidos != -1)

{

// Pasa texto claro a la función resumen

messageDigest.update(buffer);

leidos = in.read(buffer, 0, 1000);

}

in.close();

// Completar el resumen

byte[] resumen = messageDigest.digest();

// Mostrar resumen

System.out.println("RESUMEN:");

mostrarBytes(resumen);

System.out.println();

03 julio 2010

Utilidades del Sistema



No se mucho de ella. No obstante para entrar a las Utilidades del Sistema, hay que ir a Inicio, Ejecutar... y tras esto tecleear msconfig. El cmando nos abre esta ventana:


Lo poco que sé es que se puede deshabilitar el antivirus así como otros programas. También se puede seleccionar el modo de inicio, configurar el SYSTEM.INI, WIN.INI, BOOT.INI, Servicios e Inicio.

Puñetero mensaje de error del sistema: "exception processing message c0000a3 parameters"


Ayer me topé con este mensaje de error:

Previamente al combate con este mensaje, provocado por un virus, iremos akl Editor de Registro. Para hacerlo:

A. SILENCIAR EL MENSAJE DE ERROR:

Ponemos en el menú Ejecutar la intrucción Regedit, así:

Al ejecutarlo nos aparecerá una ventana como esta, y deberemos navegar hasta HKEY_LOCAL_MACHINE\System\CurrentControlSet\Control\Windows:

Cuandio lleguemos, iremos a la sección de la derecha. Escogeremos donde pone ErrorMode y cklicaremos para modificar el valor. Pondremos 1 en lugar de 0. Esto hace que se dejen de mostrar los mensajes de error. ¿Para qué? Para así poder pasar a destruir la causa de este error de memoria conforme viene a continuación explicado.



B. MATANZA DEL VIRUS:

Para cepillarnos el error hay que arrancar en modo seguro y ha
cer un análisis completo del pc, pasando el antivirus actualizado, antiespía como spybot, limpieza de registro con regseek u otro, desfragmentar el disco y terminar con un scandisk completo.
El scandisk, que se encuentra en propiedades del disco C: en herramientas , reparar errores, lo marcas y reinicia el pc.

Si continua igual debemos hacer una restauración del sistema a un día donde todo funcionaba, en accesorios, herramientas del sistema restaurar el sistema.
Que no se puede restaurar el sistema habrá que reparar el sistema con la consola de recuperación o reinstalar el sistema.



C. VOLVER A PERMITIR LA VISUALIZACIÓN DE ERRORES:


Francamete es el mejor paso, porque unok lo hace sabiendo que todo su pc ya está sano. Para ello, hay que hacer lo mismo que en el A, salvo porque aquí hay que poner 0 al ErrorMode.



Que tengan Suerte.....



Para confeccionar este manual me basé en las webs:
GRACIAS.

02 julio 2010

¿Cómo analizar y desfragmentar un disco de Windows XP?



Esta guía paso a paso describe cómo realizar el mantenimiento en volúmenes de disco en equipos basados en Windows XP. Analizar y la desfragmentar los discos sirve para mantener el rendimiento y el funcionamiento general del sistema.

Analizar y desfragmentar volúmenes

Dado que la desfragmentación de un disco puede llevar bastante tiempo (dependiendo del tamaño del volumen, el número de archivos, el porcentaje de fragmentación y la disponibilidad de los recursos del sistema), es recomendable analizar los volúmenes antes de desfragmentarlos para decidir si vale la pena o no ejecutar el proceso desfragmentación.

Analizar un volumen

Para comprobar si existen archivos o carpetas fragmentados en un volumen:
  1. Haga clic en Inicio, seleccione Todos los programas, Accesorios, Herramientas del sistema y, a continuación, haga clic en Desfragmentador de disco.
  2. Haga clic en el volumen que desea analizar.
  3. Haga clic en Analizar para empezar el análisis.
  4. Revise los resultados del análisis después de que éste se haya completado; para ello, haga clic en Presentar informes. Si la herramienta de análisis recomienda desfragmentar el volumen, siga los pasos descritos en la sección siguiente.

Desfragmentar un volumen

  1. Si la herramienta Desfragmentador de disco no se está ejecutando ya, haga clic en Inicio, elija Todos los programas, Accesorios, Herramientas del sistema,y después, haga clic en Desfragmentador de disco.
  2. Seleccione el volumen que desea desfragmentar.
  3. Haga clic en Desfragmentar para iniciar la operación.
  4. Revise el progreso de la operación en la ventana Visualización de la desfragmentación. Los archivos de disco fragmentados se muestran en rojo, los archivos contiguos en azul y los archivos del sistema en verde. El objetivo consiste en eliminar la mayor parte del color rojo de la ventana.

Errores

Aunque cualquier usuario puede tener acceso a la herramienta Desfragmentador de disco, para poder analizar o desfragmentar un volumen, se requieren privilegios de administrador. Para realizar la desfragmentación, debe iniciar sesión como administrador o como miembro del grupo local Administradores.


NOTA: La guia la he tomado del Soporte de Microsoft. Gracias

19 junio 2010

"Hazlo como quieras, total, lo va a usar un mono"





Dicen que la innformática es difícil, pero lo complejo es hacer una aplicación sencilla, casi para zopencos. Para nosotros, los sufridos desarrolladores, va dedicada esta actualización.

1 abrazo.......

03 junio 2010

Pantalla completa "sin marco" en VirtualBox


VMWare si cuenta con una opción que dispone a pantalla completa la ventana sobre la que se carga el s.o. virtual. Pero con VirtualBox nos tenemos que calentar un poquillo la cabeza porque originalmente al elegir pantalla completa nos va a salir una ventana "con un marco een negro", y como esto es una capullada, nos vamos a retorcer un poco la cabeza pensando cómo quitar el marco, que en el VMWare no salia. Pues bien, según leí en un foro esto se arregla subiendo la resolución a 800 x 600 del s.o. virtual que corremos en el momento.




Saludetes.

02 junio 2010

¿Cómo recuperar archivos borrados de la papelera de reciclaje?



La información que aquí escribo la tomé de http://www.ayudadigital.com/Manuales_informatica/recuperar_archivos_borrados.htm a los que doy las gracias. Espero que no se sientan molestos por esta copia de su manual, pues si me agregué sus conocimientos fue para tenerlos más a mano por si surgiese la necesidad de rescatarla en el trabajo.

Cuando borramos un archivo y lo eliminamos de la papelera de reciclaje , no borramos fisicamente el archivo, lo unico que hacemos es que el archivo desaparezca de la lista de programas o archivos de Windows, pero dicho archivo continua alli en nuestro disco duro hasta que escribimos nueva información encima de ellos. Si este proceso de escritura aún no ha ocurrido todavia estamos a tiempo de recuperarlos.


Para recuperar archivos borrados de la papelera de reciclaje es buenisimo este programa: Restoration 2.5.14 que no es necesario instalar y es gratuito. Para obtenerlo pulsar aqui. Al ejecutar el programa se nos crea una carpeta como la que veis a continuación

Al abrir esta carpeta nos encontraremos los siguientes archivos:



Tenemos que pinchar sobre Restoration en esta carpeta y se nos abre la siguiente ventana



Si recuerdas el nombre del fichero borrado o una parte de él, lo escribes en la casilla All or part of the file si deseas incluir los fragmentos o clusters ocupados por ficheros que han escrito encima marca la casilla Include used cluster. Para recuperar el archivo incluso aunque tenga un tamaño de 0 bits , activa la casilla Include even . Por último, pulsa el botón Search Deleted Files y obtendras los archivos borrados que cumplan esas condiciones.



Si tenemos la suerte de encontrarlos, podemos recuparlos pulsando el icono Restore by copying.

En ocasiones es posible que no recordemos los nombres de los ficheros eliminados, en este caso no queda otra solución que hacer un barrido de la unidad para recuperar cualquier informacion coherente. Para ello entramos en el menu Others y marcamos sobre Scan all clusters. Los archivos recuperados podremos devolverlos a su ubicación original con el mencionado boton Restore by Copying.


Saludetes.


23 mayo 2010

Ideas para proyectos propios (I) y (II)


Utilizando C sharp haré una aplicación que transfiera archivos de un teléfono móvil a un ordenador a través de bluetooth y viceversa.

Y luego, haré otra para realizar copias de seguridad de la agenda del teléfono a una base de datos dl ordenador. Así mismo esta copia podrá ser exportada al télefono.

Estos dos links me servirán de algo:

Transferring files and monitoring Bluetooth ports in C#

Scanning for bluetooth devices

Importante libreria: http://www.desarrollomobile.net/devmob/BluetoothLibrary/tabid/54/Default.aspx

A ver cuánto tardo.

10 mayo 2010

Cómo hacer práctico un Pen drive para que se puedan guarrdar archivos "grandes"

Es fácil.

1. Vamos a las propiedades de MI PC (pinchando con el botón derecho).
2. Tras esto clicamos en Administrador de dispositivos.
3. Seleccionamos Unidades de Almacenamiento, pinchamos sobre USB.
4. Luego, nos salen sus propiedades, y de ahí escogemos Directivas. Entonces de las dos opciones OPTIMIZAR PARA RENDIMIENTO es la buena.
5. Aceptamos.
6. Fotmateamos el pen drive.

Y listo.

02 mayo 2010

En C#: Cómo montar un navegador en un TreeView ( 2º versión)

Para desarrollar esta segunda versión, que sustituye, mejorando a "Más código en C#: Cómo montar un navegador en un TreeView", cree una clase. La llamé "SuperTreeNode" y hereda todo de la clase "TreeNode" perteneciente a System.Windows.Forms.

Código de la clase SuperTreeNode:

class SuperTreeNode:TreeNode //los dos puntos preceden a la clase superior
{
private string ruta;

public SuperTreeNode()
: base()
{
this.ruta = "";
}
public SuperTreeNode(string ruta)
: base()
{
this.ruta = ruta;
}
public SuperTreeNode(string texto, string ruta):base(texto)
{
this.ruta = ruta;
}
public string Ruta
{
get { return ruta; }
set { ruta = value; }
}

}



El código de la clase donde se realizan las funciones relativas a la carga de los directorios, en esta versión, se cargan cuando se procede a utilizarlos, resolviendo asi el problemas con la memoria RAM, que antes se veia afectada.

Código de la clase del formulario principal, donde uso System.IO;:

public partial class Form1 : Form
{
SuperTreeNode NodoRaiz;

public Form1()
{
InitializeComponent();
NodoRaiz = new SuperTreeNode();

NodoRaiz.ImageIndex = 0;
NodoRaiz.Text = "MI PC"; //doy un texto al nodo primario

TreeVArboleda.Nodes.Add(NodoRaiz); //el nodoprimario lo agrego al arbol
}

private void Form1_Load(object sender, EventArgs e)
{

Inicio();

TreeVArboleda.ExpandAll();
}

public void Inicio()
{
//lo primero, sacar las unidades.
DriveInfo[] drivers = DriveInfo.GetDrives();//se obtienen todos los drivers
foreach (DriveInfo driver in drivers)
{
try
{
//de cada driver se obtiene el nombre y el fullname y se convierte a nodo. El nodo se agrega al principal
SuperTreeNode nodo = new SuperTreeNode();
nodo.Text = driver.Name; //nombre
nodo.Ruta = driver.RootDirectory.FullName; //ruta

NodoRaiz.Nodes.Add(nodo);

StateLblInformacion.Text ="";

}
catch (Exception ex)
{
StateLblInformacion.Text = ex.Message;
}
}

}

private void TreeVArboleda_AfterSelect(object sender, TreeViewEventArgs e)
{
SuperTreeNode nodo = (SuperTreeNode)e.Node;

TxtRutaActual.Text = nodo.Ruta; //obtengo la ruta seleccionada

try
{
//obtengo el contenido (subdirectorios) del directorio de la ruta
DirectoryInfo unDirectorio = new DirectoryInfo(TxtRutaActual.Text);

DirectoryInfo[] subdirectorios = unDirectorio.GetDirectories();
nodo.Nodes.Clear();

foreach (DirectoryInfo directorios in subdirectorios)
{
try
{
//por cada subdirectorio cro un nodo llamado hijo al que anclo al nodo creado al principio
SuperTreeNode hijo = new SuperTreeNode(directorios.Name, directorios.FullName);

nodo.Nodes.Add(hijo);

StateLblInformacion.Text = "";

}
catch (Exception ex2)
{

StateLblInformacion.Text = ex2.Message;
}
}
}
catch (Exception ex)
{
StateLblInformacion.Text = ex.Message;
}


}
}
}

Saludos.

17 abril 2010

Cómo en C# obtener el tamaaño de un directorio

Esta misma función la escribí en el post anterior, pero creo necesario volverla a escribir porque puede ser útil al márgen de la otra utilidad que le dí.

private long ObtenerPesoDirectorioEnBytes(DirectoryInfo d)
{

long pesoDir = 0;

try
{

// Totalizar tamaño de archivos

FileInfo[] fis = d.GetFiles();

foreach (FileInfo fi in fis)
{

pesoDir += fi.Length;

}

// Totalizar tamaño sub-directorios

DirectoryInfo[] dis = d.GetDirectories();

foreach (DirectoryInfo di in dis)
{

pesoDir += ObtenerPesoDirectorioEnBytes(di);

}

}

catch (Exception exp)
{

// Código para la excepción va aquí

}

return pesoDir;

}


Por su puesto, gracias a quién colgó por internet este código, del que yo no he cambiado nada.

Saludos

Más código en C#: Cómo montar un navegador en un TreeView

Para implementar este código utilicé una clase, que llamé ExploradorLocal. Para su programación he usado clase IO y Windows.Forms, donde la primera se usa para el manejo de archivos y directorios. Y la otra sirve para manipular TreeView y TreeNode, clases que usaremos para el árbol, donde la segunda, es obviamente la que crea nodos dependientes del árbol.

Esta clase cuenta cobn un objeto ArrayList que es Contenedor y que contiene el contenido del directorio. También trabajo con la clase ContenidoDirectorio, la cual tiene como variables nombre, tipo, ultima fecha de acceso y peso. Las tres primeras del tipo string, y la cuarta long. En el ArrayList se meterá cada componente conforme se vaya leyendo el contenido del directorio, y esto sucede enla tercera de la funciones (métodos si usamos la nomenclatura de POO).

La primera función, ExtraerEstructuraUnidades() , devuelve un objeto TreeView, donde ya se "cargaron" todas las ramificacones del arbol. Esta función se ocupa de encontrar las unidades (drivers).

public TreeView ExtraerEstructuraUnidades()
{
/*Extrae las unidades*/
try
{

oTree.Nodes.Clear();


DriveInfo[] TodosLosDrivers = DriveInfo.GetDrives();
foreach (DriveInfo driver in TodosLosDrivers)
{
TreeNode node = new TreeNode();

node.Text = driver.Name;
oTree.Nodes.Add(node);
ExtraerEstructuraDirectorios(driver.Name, node, 0);
}
}
catch (Exception ex)
{
ex.ToString();
}
return oTree;
}

La siguiente, que es recursiva tiene por finalidad, extraer los directorios que cuelgan de la ruta especificada. Superior es el nodo superior, y nivel es una variable que hace de tope, impidiendo el bucle infinito.

private void ExtraerEstructuraDirectorios(string ruta, TreeNode superior, int nivel)
{
/*Extrae el contenido de cada unidad (solo directorios)*/
try
{
nivel++;
if (nivel == 4)
return;
DirectoryInfo dir = new DirectoryInfo(ruta);
if (!dir.Exists)
Console.WriteLine("No se puede acceder a: " + ruta);
foreach(DirectoryInfo dirInfo in dir.GetDirectories())
{
TreeNode child = new TreeNode();
child.Text = dirInfo.Name;
superior.Nodes.Add(child);
ExtraerEstructuraDirectorios(child.FullPath, child, nivel);
}

}
catch (Exception ex)
{
Console.WriteLine("Ha surgido un problema: " +ex.Message);
}
}

En esta tercera función se extrae el contenido del directorio actual, aarchivos y subdirectorios, para luego, y aunque aquí no se vea, cargar su información en un objeto GridView.

public void ObtenerContenidoDirectorio()
{
/*Extrae el contenido de cada directorio (subdirectorios y ficheros)*/
Contenedor.Clear(); //borrado del arraylist
try
{
// miro si la ruta existe
DirectoryInfo dir = new DirectoryInfo(rutaSeleccionada);
if (!dir.Exists)
Console.WriteLine("El directorio " + rutaSeleccionada + " no existe.");

// lista del contenido
foreach (DirectoryInfo di in dir.GetDirectories())
{
//se obtiene el peso en bytes del subdirectorio
long peso = ObtenerPesoDirectorioEnBytes(di);
//oContenido contiene un elemento del directorio
Clases.ContenidoDirectorio oContenido = new Proyecto .Clases.ContenidoDirectorio(di.Name, "Subdirectorio", Convert.ToString(di.LastWriteTime), peso);
//Contenedor contiene muchos oContenido
Contenedor.Add(oContenido);
}

// fill the Files listbox
foreach (FileInfo fi in dir.GetFiles())
{
Clases.ContenidoDirectorio oContenido = new Proyecto.Clases.ContenidoDirectorio(fi.Name, fi.Extension, Convert.ToString(fi.LastWriteTime), fi.Length);
Contenedor.Add(oContenido);
}

}
catch (Exception ex)
{
ex.ToString();

}


}

En esta cuarta función se extrae el peso en bytes de un directorio (pasado por parametro).

private long ObtenerPesoDirectorioEnBytes(DirectoryInfo d)
{

long pesoDir = 0;

try
{

// Totalizar tamaño de archivos

FileInfo[] fis = d.GetFiles();

foreach (FileInfo fi in fis)
{

pesoDir += fi.Length;

}

// Totalizar tamaño sub-directorios

DirectoryInfo[] dis = d.GetDirectories();

foreach (DirectoryInfo di in dis)
{

pesoDir += ObtenerPesoDirectorioEnBytes(di);

}

}

catch (Exception exp)
{

// Código para la excepción va aquí

}

return pesoDir;

}


Para realizar este proyecto, cuya idea es imitar a Filezilla, estoy utilizando código encontrado pr Internet, así pues gracias a aquellos que me ilustran.

Saludos