вторник, 17 июня 2014 г.

Linux. Change file creation timestamp. Изменить timestamp у файла


Задача:
Изменить timestamp у файла

Решение:
touch -t 200805101024 filename

Linux. Remove files older than 10 days. Удалить файлы старше 10 дней


Задача:
Необходимо удалить много мелких файлов, созданных более 10 дней назад.

Решение:
Из папки в которой хотим удалить файлы вызвать команду:
find ./ -ctime +10 | xargs rm

понедельник, 19 мая 2014 г.

Разбить List на подлисты фиксированного размера (Split list to sublist with fixed batch size in java)


Задача:
Имеется лист, который необходимо разбить на подлисты по 10 элементов.

Решение:
package com.blogspot.happygilmor89;

import java.util.ArrayList;
import java.util.List;

public class PartitionsList {
    private static int BATCH_SIZE = 10;
    private static int LIST_SIZE = 235;
    public static void main(String[] args) {

     List<Integer> list = new ArrayList<Integer>(LIST_SIZE);

     for (int i = 0; i < LIST_SIZE; i++) {
        list.add(i);
     }

     for (int i = 0; i < LIST_SIZE; i+=BATCH_SIZE) {
        System.out.println(list.subList(i, Math.min(
LIST_SIZE, i + BATCH_SIZE)));
     }
    }
}


Результат:

[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
[10, 11, 12, 13, 14, 15, 16, 17, 18, 19]
[20, 21, 22, 23, 24, 25, 26, 27, 28, 29]
[30, 31, 32, 33, 34, 35, 36, 37, 38, 39]
[40, 41, 42, 43, 44, 45, 46, 47, 48, 49]
[50, 51, 52, 53, 54, 55, 56, 57, 58, 59]
[60, 61, 62, 63, 64, 65, 66, 67, 68, 69]
[70, 71, 72, 73, 74, 75, 76, 77, 78, 79]
[80, 81, 82, 83, 84, 85, 86, 87, 88, 89]
[90, 91, 92, 93, 94, 95, 96, 97, 98, 99]
[100, 101, 102, 103, 104, 105, 106, 107, 108, 109]
[110, 111, 112, 113, 114, 115, 116, 117, 118, 119]
[120, 121, 122, 123, 124, 125, 126, 127, 128, 129]
[130, 131, 132, 133, 134, 135, 136, 137, 138, 139]
[140, 141, 142, 143, 144, 145, 146, 147, 148, 149]
[150, 151, 152, 153, 154, 155, 156, 157, 158, 159]
[160, 161, 162, 163, 164, 165, 166, 167, 168, 169]
[170, 171, 172, 173, 174, 175, 176, 177, 178, 179]
[180, 181, 182, 183, 184, 185, 186, 187, 188, 189]
[190, 191, 192, 193, 194, 195, 196, 197, 198, 199]
[200, 201, 202, 203, 204, 205, 206, 207, 208, 209]
[210, 211, 212, 213, 214, 215, 216, 217, 218, 219]
[220, 221, 222, 223, 224, 225, 226, 227, 228, 229]
[230, 231, 232, 233, 234]

суббота, 3 августа 2013 г.

Удалить дубликаты из таблицы mysql (Remove duplicates in table mysql)

Есть таблица test_table вида:

duplicate_idvalue
10
20
31
41
52
62
Задача: необходимо удалить строки с дубликатами значений value

Решение:
DELETE FROM test_table WHERE duplicate_id NOT IN 
(SELECT * FROM (SELECT duplicate_id FROM test_table
                GROUP BY value) AS d); 


Результат выполнения:
duplicate_idvalue
10
31
52

Возможно для выполнения скрипта придется отключить опцию безопасного обновления таблицы в mySQL:
 Edit -> Preferences -> SQL Queries ->"Safe Updates" и сделать реконнект.

вторник, 19 февраля 2013 г.

C#: Добавить префикс всем дочерним элементам объекта XmlElement:

Новый префикс проставляется в результате рекурсивного обхода всего дерева:

        private void SetPrefix(String prefix, XmlNode node) {
            foreach (XmlNode n in node.ChildNodes)
            {
                SetPrefix(prefix, n);
                n.Prefix = prefix;
            }
        }


понедельник, 28 января 2013 г.

Заполнить dojo 1.3 FilteringSelect ItemFileReadStore, используя javascript

Задача состоит в том, чтобы заполнить выпадающий список FilteringSelect списком значений, полученным от какого-либо плагина.
Решение:

//получаем ссылку на filteingSelect
    var nameoptions = dijit.byId('resourcename');
//обнуляем его
    nameoptions.innerHTML = "";   
//создаем пустой массив items
    var items = [];

    for (i = 0; i &lt; plugin.Count; i++) {
//заполняем массив item объектами
        items[i] = {
                    abbr: plugin.abbrItems(i),
                    name:  plugin.nameItems(i)
                    };
        }
// заполнение data для
ItemFileReadStore
        var options = {
            identifier: 'abbr',
            label: 'name',
            items: items
        };
    nameoptions.store = new dojo.data.ItemFileReadStore({ data: options });

вторник, 18 декабря 2012 г.

JavaScript: получение поля cookie из сессии по имени 

На вход функция принимает имя параметра. Возвращает или значение или пустую строку, если поля не существует.


function get_cookie(name) {
   var start = document.cookie.indexOf(name + "=");
   var len = start + name.length + 1;
   if ((!start) 

       && (name != document.cookie.substring(0, name.length))) 
     return "";
   if (start == -1) 

     return "";
   var end = document.cookie.indexOf(";",len);
   if (end == -1) 

     end = document.cookie.length;
   return unescape(document.cookie.substring(len,end));
}