Форум программистов, компьютерный форум, киберфорум
Visual Basic
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.95/21: Рейтинг темы: голосов - 21, средняя оценка - 4.95
2 / 2 / 0
Регистрация: 25.08.2013
Сообщений: 38

В одном столбце таблицы БД заменить все пустые ячейки на содержимое ячеек в другом столбце из той же строки

23.01.2014, 17:21. Показов 4216. Ответов 14
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день.

Есть таблица .dbf и надо в одном столбце заменить все пустые ячейки на содержимое ячеек в другом столбце из той же строки.
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
23.01.2014, 17:21
Ответы с готовыми решениями:

Осуществить протягивание значений в одном столбце до строки последней заполненной ячейки в другом столбце
Доброго времени суток! Нужна помощь... Есть такая не тривиальная задача которую я даже не представляю как решить.. есть два...

Как посчитать значения в столбце при условии того что в другом столбце напротив пустые ячейки
Всем привет, как посчитать значения в столбце при условии того что в другом столбце напротив пустые ячейки, прилагаю файл. В ручную я делаю...

Разбитие числа во все не пустые ячейки в столбце. Как сделать?
Здравствуйте задача состоит вот в чем, есть число и нужно его разбить на все не пустые ячейки в столбце над ним. Чтоб было более понятно...

14
 Аватар для Alex77755
11525 / 3812 / 683
Регистрация: 13.02.2009
Сообщений: 11,229
23.01.2014, 21:25
Подсказка с чего начать
Там вложение 875.zip
0
2 / 2 / 0
Регистрация: 25.08.2013
Сообщений: 38
24.01.2014, 12:30  [ТС]
Да Я бы и рад изучить всё это дело, да просто сейчас совсем некогда, а начальство требует редактировать таблицу...
Помогли бы формулой какой, был бы безмерно благодарен!
0
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38161 / 21096 / 4306
Регистрация: 12.02.2012
Сообщений: 34,680
Записей в блоге: 14
24.01.2014, 14:33
Загружаешь dbf в Excel, правишь, сохраняешь.
0
2 / 2 / 0
Регистрация: 25.08.2013
Сообщений: 38
24.01.2014, 15:08  [ТС]
Цитата Сообщение от Catstail Посмотреть сообщение
Загружаешь dbf в Excel, правишь, сохраняешь.
Нельзя, данные теряются. Там еще с кодировкой как то не так.
0
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38161 / 21096 / 4306
Регистрация: 12.02.2012
Сообщений: 34,680
Записей в блоге: 14
24.01.2014, 17:39
Выложи тестовый dbf-ник.
0
2 / 2 / 0
Регистрация: 25.08.2013
Сообщений: 38
28.01.2014, 12:27  [ТС]
Цитата Сообщение от Catstail Посмотреть сообщение
Выложи тестовый dbf-ник.
test.rar
Вот, так еще и не разобрался.

Задача:
1. Во всех пустых полях Nprik поставить - (тире)
2. В столбце Data_pr заменить все "не даты" датами из столбца Datn из той же строки.
1
2 / 2 / 0
Регистрация: 25.08.2013
Сообщений: 38
29.01.2014, 12:43  [ТС]
Цитата Сообщение от Catstail Посмотреть сообщение
Выложи тестовый dbf-ник.
Пользуясь DBFNavigator удалось изменить NPRIK такой командой:

PureBasic
1
IFF (nprik="",nprik="-",nprik=nprik)
Но почему то он не тире поставил, а нули...

А для столбца DATA_PR выдает ошибку (не соответствие типов оператора\операндов) при таком коде:

PureBasic
1
IFF (data_pr="",data_pr=datn,data_pr=data_pr)
Команды запускаются для выделенных ячеек.
0
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38161 / 21096 / 4306
Регистрация: 12.02.2012
Сообщений: 34,680
Записей в блоге: 14
29.01.2014, 14:03
Я сегодня вечером напишу код для Excel-а. Постараюсь.
0
2 / 2 / 0
Регистрация: 25.08.2013
Сообщений: 38
29.01.2014, 14:42  [ТС]
Цитата Сообщение от Catstail Посмотреть сообщение
Я сегодня вечером напишу код для Excel-а. Постараюсь.
Так в Excel-e не открыть, он открывает неведомые символы и записи (что 03, что 07, что 10)... Даже что то похожее на таблицу не открывает.
0
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38161 / 21096 / 4306
Регистрация: 12.02.2012
Сообщений: 34,680
Записей в блоге: 14
29.01.2014, 15:03
Сделаю, работать будет.
0
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38161 / 21096 / 4306
Регистрация: 12.02.2012
Сообщений: 34,680
Записей в блоге: 14
29.01.2014, 19:53
Лучший ответ Сообщение было отмечено The trick как решение

Решение

Сделал. Выкладываю законченное приложение в Excel

Кликните здесь для просмотра всего текста
Visual Basic
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
Sub Main()
Dim flg             As Boolean
Dim fldNam(1 To 20) As String
Dim fldOff(1 To 20) As String
Dim fldLen(1 To 20) As String
    dbf$ = Application.GetOpenFilename("Файлы dbf,*.dbf", , "Выбирайте файл")
    If UCase$(dbf$) = "FALSE" Or UCase$(dbf$) = "ЛОЖЬ" Then Exit Sub
    fi% = FreeFile
    Open dbf$ For Binary Access Read Write As #fi%
    Seek fi%, 5
    Get #fi%, , Nrec&
    Get #fi%, , OffBeg%
    Get #fi%, , Lrec%
    p& = 33
    n% = 0
    Do
       Seek #fi%, p&
       C11$ = Space$(11)
       Get #fi%, , C11$
       If Left$(C11$, 1) = Chr$(13) Then Exit Do
       n% = n% + 1
       k% = InStr(C11$, Chr$(0))
       If k% = 0 Then
          fldNam(n%) = C11$
       Else
          fldNam(n%) = Left(C11$, k% - 1)
       End If
       tmp$ = " "
       Get #fi%, , tmp$
       Get #fi%, , Off&
       Get #fi%, , ll%
       fldOff(n%) = Off& + 1
       fldLen(n%) = ll%
       p& = p& + 32
    Loop
    For i% = 1 To n%
        If UCase$(fldNam(i%)) = "NPRIK" Then
           Off_Nprik% = fldOff(i%)
           Len_Nprik% = fldLen(i%)
        ElseIf UCase$(fldNam(i%)) = "DATA_PR" Then
           Off_Datapr% = fldOff(i%)
           Len_Datapr% = fldLen(i%)
        ElseIf UCase$(fldNam(i%)) = "DATN" Then
           Off_Datn% = fldOff(i%)
           Len_Datn% = fldLen(i%)
        End If
    Next i%
    Seek #fi%, OffBeg% + 1
    For iii& = 1 To Nrec&
        Application.StatusBar = "Обработка записи " + CStr(iii&)
        Buf$ = Space$(Lrec%)
        Get #fi%, , Buf$
        flg = False
        If Mid$(Buf$, Off_Nprik%, Len_Nprik%) = Space$(Len_Nprik%) Then
           Mid$(Buf$, Off_Nprik%, 1) = "-"
           flg = True
        End If
        If Mid$(Buf$, Off_Datapr%, Len_Datapr%) = Space$(Len_Datapr%) Then
           Mid$(Buf$, Off_Datapr%, Len_Datapr%) = Mid$(Buf$, Off_Datn%, Len_Datn%)
           flg = True
        End If
        If flg Then
           ppp& = Loc(fi%)
           Seek fi%, ppp& - Lrec% + 1
           Put #fi%, , Buf$
        End If
    Next iii&
    Close #fi%
    Application.StatusBar = ""
    MsgBox "Готово!"
End Sub


Во вложении твой dbf-ник, обработанный программой. Открываешь книгу, щелкаешь по надписи "Пуск", выбираешь файл.
Вложения
Тип файла: zip Задачи-VBA-B3.zip (72.6 Кб, 6 просмотров)
1
2 / 2 / 0
Регистрация: 25.08.2013
Сообщений: 38
30.01.2014, 08:52  [ТС]
Цитата Сообщение от Catstail Посмотреть сообщение
Сделал. Выкладываю законченное приложение в Excel

Кликните здесь для просмотра всего текста
Visual Basic
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
Sub Main()
Dim flg             As Boolean
Dim fldNam(1 To 20) As String
Dim fldOff(1 To 20) As String
Dim fldLen(1 To 20) As String
    dbf$ = Application.GetOpenFilename("Файлы dbf,*.dbf", , "Выбирайте файл")
    If UCase$(dbf$) = "FALSE" Or UCase$(dbf$) = "ЛОЖЬ" Then Exit Sub
    fi% = FreeFile
    Open dbf$ For Binary Access Read Write As #fi%
    Seek fi%, 5
    Get #fi%, , Nrec&
    Get #fi%, , OffBeg%
    Get #fi%, , Lrec%
    p& = 33
    n% = 0
    Do
       Seek #fi%, p&
       C11$ = Space$(11)
       Get #fi%, , C11$
       If Left$(C11$, 1) = Chr$(13) Then Exit Do
       n% = n% + 1
       k% = InStr(C11$, Chr$(0))
       If k% = 0 Then
          fldNam(n%) = C11$
       Else
          fldNam(n%) = Left(C11$, k% - 1)
       End If
       tmp$ = " "
       Get #fi%, , tmp$
       Get #fi%, , Off&
       Get #fi%, , ll%
       fldOff(n%) = Off& + 1
       fldLen(n%) = ll%
       p& = p& + 32
    Loop
    For i% = 1 To n%
        If UCase$(fldNam(i%)) = "NPRIK" Then
           Off_Nprik% = fldOff(i%)
           Len_Nprik% = fldLen(i%)
        ElseIf UCase$(fldNam(i%)) = "DATA_PR" Then
           Off_Datapr% = fldOff(i%)
           Len_Datapr% = fldLen(i%)
        ElseIf UCase$(fldNam(i%)) = "DATN" Then
           Off_Datn% = fldOff(i%)
           Len_Datn% = fldLen(i%)
        End If
    Next i%
    Seek #fi%, OffBeg% + 1
    For iii& = 1 To Nrec&
        Application.StatusBar = "Обработка записи " + CStr(iii&)
        Buf$ = Space$(Lrec%)
        Get #fi%, , Buf$
        flg = False
        If Mid$(Buf$, Off_Nprik%, Len_Nprik%) = Space$(Len_Nprik%) Then
           Mid$(Buf$, Off_Nprik%, 1) = "-"
           flg = True
        End If
        If Mid$(Buf$, Off_Datapr%, Len_Datapr%) = Space$(Len_Datapr%) Then
           Mid$(Buf$, Off_Datapr%, Len_Datapr%) = Mid$(Buf$, Off_Datn%, Len_Datn%)
           flg = True
        End If
        If flg Then
           ppp& = Loc(fi%)
           Seek fi%, ppp& - Lrec% + 1
           Put #fi%, , Buf$
        End If
    Next iii&
    Close #fi%
    Application.StatusBar = ""
    MsgBox "Готово!"
End Sub


Во вложении твой dbf-ник, обработанный программой. Открываешь книгу, щелкаешь по надписи "Пуск", выбираешь файл.
Спасибо большое.
Серьезное такое решение) Я искал что то проще и нашел.

Все уложилось в две команды для FoxPro.
PureBasic
1
2
repl nprik with "-" for nprik="0"
repl data_pr with datn for nprik="-"
Еще раз спасибо за ответ, будет как пособие VB с базами данных.
0
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38161 / 21096 / 4306
Регистрация: 12.02.2012
Сообщений: 34,680
Записей в блоге: 14
30.01.2014, 11:05
Так у тебя FoxPro под руками? А чего было тогда грузить?...
0
2 / 2 / 0
Регистрация: 25.08.2013
Сообщений: 38
30.01.2014, 11:14  [ТС]
Цитата Сообщение от Catstail Посмотреть сообщение
Так у тебя FoxPro под руками? А чего было тогда грузить?...
Я до этого никогда не пользовался FoxPro, я даже не знал что он открывает .dbf, а до кучи я даже не предполагал что FoxPro это своего рода компилятор.
У нас он ставиться с программой для учета.

А покапавшись в инете по языку dBase нашел вот эту команду и то что в FoxPro юзать её лучше.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
30.01.2014, 11:14
Помогаю со студенческими работами здесь

Перенос значение ячейки в другую ячейку при появлении первой информации в соседнем столбце той же строки
Всех женщин с праздником 8-го марта! :kissing: Подскажите пожалуйста, как выводить значение ячейки в другую ячейку при условии...

В заданной матрице найти минимальный элемент и заменить на него все элементы в той же строке и столбце
Дана квадратная матрица А порядка n. Составить программу, которая находит минимальный элемент и все элементы, расположенные в одной строке...

Как выделить цветом значения в столбце, которые содержатся в другом столбце другого листа
Как выделить цветом значения в столбце , которые содержатся в другом столбце другого листа ?

Выбор значений в одном столбце по одинаковым значениям в другом
Добрый день! Помогите пожалуйста! Есть таблица, в которой хранятся все изменения с файлом. В частности, дополнение описания. По...

Ячейки в одном столбце, но с разными масками
В продолжение темы(когда-то спрашивала про ячейки разной ширины в одном столбце, решили что все ячейки в столбцах будут одной ширины )...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
15
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru